标签:
输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。
这道题的思路是用:整数与整数本身进行相与得出来的。
知识点:整数与整数本身相与,可以将整数的二进制中最右边(不是0的位置)的1消掉。所以,有多少个1,循环就执行几次;反过来说,循环执行几次,就有几个1.
public int NumberOf1(int n) { int count = 0; while(n!=0){ count++; n &= (n-1); } return count; }
标签:
原文地址:http://www.cnblogs.com/yingpu/p/5813438.html