码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 位级运算之计算整数位级表示奇偶性


    位级运算之计算整数位级表示奇偶性

    Author:Once day Date:2022年7月31日

    漫漫长路刚刚开始,不要甘于平凡。

    本算法基于C语言环境。

    1.引言

    可以只依靠基本的位级运算来计算位级表示的奇偶性。

    如一个含有w位的向量 b n − 1 b n n − 2 ⋅ ⋅ ⋅ ⋅ ⋅ ⋅ b 1 b 0 b_{n-1}bn_{n-2}······b_1b_0 bn−1​bnn−2​⋅⋅⋅⋅⋅⋅b1​b0​。

    如果其中有奇数个位为1,那么返回值1,否则返回0。

    如,[0001]返回1,[0011]返回0。

    那么存在一种对数增长度的算法,来计算其值,而且无需判断语句。

    2.实现

    最简单的实现方式就是依次判断每位是否为1,然后累积起来,判断是否为奇数个。这样效率太低。

    可以依靠异或运算加速判断。

    这里假设w=8位:

    对于形如[01010111]的位级表示,其有奇数个1,所以应该返回1。

    异或运算规律如下:

    值值结果
    000
    011
    110

    因此,将[01010111]拆成两半,即[0101]和[0111],然后异或0101b ^ 0111b = 0010b,如果有一对1,那么该位异或结果为0,如果有一个1,那么结果为1。

    对于[0010],则可以拆分成[00]和[10],按此规律继续异或,最终将为1。

    根据配对规则,如果有奇数个1,那么最后异或一定剩下1,该算法是递归的,其复杂度为 l o g 2 w log_2w log2​w。

    可表示为:

    unsigned x; //假设32位
    x=x^(x>>16);
    x=x^(x>>8);
    x=x^(x>>4);
    x=x^(x>>2);
    x=x^(x>>1);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6


    完…

  • 相关阅读:
    LeetCode_模拟_中等_2596.检查骑士巡视方案
    Quartz 基本使用,任务调度quartz详解,动态定时任务,job,Trigger,Scheduler
    小程序request请求封装
    QT6 C++获取Linux系统计算机的主机BIOS序列号源代码
    分析 NFT 项目的 5 个指标
    第一次接触web前端开发
    NK-RTU980烧写裸机程序
    C#中Semaphore 和 CountdownEvent 的使用总结
    原生GO开发的博客系统
    Java面试题:Java高频面试题,可以说下阻塞队列被异步消费怎么保持顺序吗?
  • 原文地址:https://blog.csdn.net/Once_day/article/details/126085241
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号