zoukankan      html  css  js  c++  java
  • 小技巧,计算一个十进制整数在二进制下“1”的个数

    在写百度之星的时候遇到这个困难,要查看被压缩的状态里,有几个已处理的对象。c++里可以用一个函数来解决,但是运算复杂度高,在多组数据时没有优势,而且在高中竞赛中也禁止使用。

    所以我写了一个预处理,处理出数据范围内所有数在二进制下有几个1,并存进数组里。

    想法

    ans->0

    对每个数都mod 2,如果为1,则ans++;//即查看每位上是否为2

    最后ans->0 

    循环以上步骤计算出所有数

    有n个数

    每个数i计算logi次

    n

    ∑logi

    i=1

    复杂度:O(nlogn)

    后来在大佬的指点下,发现了可以用递推

    计算count[a]的时候只要count[a>>1]计算出来了,那么如果a二进制下的末位为1,结果加1,否则不变

    a>>1是位运算,就是把a在二进制下直接向右移,那么它的最后一位就没了。

    example

    101001111我们要计算它的1的个数,只要把10100111的1的个数加一就好了

    101001110我们要计算它的1的个数,它是等于10100111的

    那么我们的程序就出来了

    #include<iostream>
    #include<cstdlib>
    using namespace std;
    int main()
    {
        int count[1<<16];
        for(int i=1;i<=(1<<16);i++)
        {
                if((i&1)==0)
                count[i]=count[i>>1];
                else
                count[i]=count[(i>>1)]+1;
                //cout<<i<<" "<<count[i]<<endl;
                //system("pause");
        }
    }
    

    这里有一个&运算,可能有人不懂

    &就是把两个数在二进制下,每一位进行与运算,a&1就可以知道a的最后一位是什么









  • 相关阅读:
    JavaScript条件判断和循环
    JavaScript数据类型详解
    Dockerfile使用
    让ie8、ie9支持媒体查询
    事件穿透
    判断是苹果手机还是安卓手机
    ES6中字符串的扩展
    ES6数组的扩展运算符
    let和const
    ES6中函数的扩展
  • 原文地址:https://www.cnblogs.com/sherrlock/p/9525796.html
Copyright © 2011-2022 走看看