9,求整数的二进制中1的个数《剑指offer》

题目:

输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。

思路:

通过 1 的左移来和这个整数的每一位进行与操作,计算出二进制中1的个数

代码:

class Solution {
public:
     int  NumberOf1(int n) {
         int count=0;
         int flag=1;
         while(flag){
            if(n&flag) count++;
             flag = flag << 1;
         }
         
         return count;
     }
};

  

posted @ 2017-09-13 15:32  llauser  阅读(135)  评论(0)    收藏  举报