最好的方式:
思想:一个整数减去1,再和原整数做与运算,会把该整数最右边一个1变成0.那么一个整数的二进制表示中有多少个1,就可以进行多少次这样的操作。
int NumberOf1(int n)
{
int count = 0;
while(n != 0)
{
count++:
n = (n - 1) & n;
}
return count;
}
本文介绍了一种利用整数减一与运算的方法来计算整数二进制表示中1的数目。通过不断执行此操作直至结果变为0,可以精确计算出整数内有多少位为1。
最好的方式:
思想:一个整数减去1,再和原整数做与运算,会把该整数最右边一个1变成0.那么一个整数的二进制表示中有多少个1,就可以进行多少次这样的操作。
int NumberOf1(int n)
{
int count = 0;
while(n != 0)
{
count++:
n = (n - 1) & n;
}
return count;
}
797
773

被折叠的 条评论
为什么被折叠?