题目描述:输入一个整数,输出该数二进制表示中1的个数。其中负数用补码表示。
代码:
import java.util.*;
public class Solution {
public int NumberOf1(int n) {
int index=0;
if(n>0){
int r=n;
while(r>0){
int m=r%2;
if(m==1){index++;}
r=r/2;
}
}
else if(n<=0){
int flag=1;
while(flag!=0){
if((n&flag)!=0){index++;}
flag=flag<<1;
}
}
return index;
}
}
如红色代码地方:我们在用位操作符进行运算的时候,使用的if语句 if(n&flag!=0)而不能使用 if(n&flag==1).因为在位运算中比如 n=5,我们 flag=1;这时候我们每一次循环:flag=1;n&flag==1;flag<<1;-------> flag=2;n&flag==0;flag<<1; --------> flag=4;n&flag==4;flag<<1; 他比较的是每个位置上的值是否相等,但是返回的是对应位置的值(第一位为1 如果值相同就返回1,第二位为2 如果值相等返回2,第三位为4 如果值相等返回为4)或0(当对应位置值不同时)。所以我们在对位与的返回值进行判定的时候不能使用 if(n&flag==1)只能使用 if(n&flag!=0)。