加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 09:19:39 所属栏目:百科 来源:网络整理
导读:这道题的思路主要是打破自己的惯有的思维,其实我们可以看出10进制的数,我们完全可以当做二进制来使用。 然后在转换成为二进制的时候,我们可以看到他是用了一个左移的操作, 这个操作比我们传统的利用对二连除的方法要好的。然后我们用c++的方法进行求解得

这道题的思路主要是打破自己的惯有的思维,其实我们可以看出10进制的数,我们完全可以当做二进制来使用。

然后在转换成为二进制的时候,我们可以看到他是用了一个左移的操作,

这个操作比我们传统的利用对二连除的方法要好的。然后我们用c++的方法进行求解得到的答案就是

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

通过java写出的代码为

思路为:先将数字转换为一个string类型的字符串,然后再将这个字符串转换为数组。然后

对这个数字转换成的数组进行遍历。看里面有的1的个数,就可以了。

public class Solution {
public int NumberOf1(int n) {
int number =0;
String string=Integer.toBinaryString(n);
char[]chars=string.toCharArray();
for(char ch:chars){
if(ch==‘1‘)
number++;
}
return number;
}
}

c++和java其实代码写的在这道题中是都是适用的。两者的风格是非常的类似的

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读