博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
8、二进制中1的个数------------>剑指offer系列
阅读量:5334 次
发布时间:2019-06-15

本文共 714 字,大约阅读时间需要 2 分钟。

题目

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

法一:分析

这是一道考察二进制的题目

二进制或运算符(or):符号为|,表示若两个二进制位都为0,则结果为0,否则为1

二进制与运算符(and):符号为&,表示若两个二进制位都为1,则结果为1,否则为0

二进制否运算符(not):符号为~,表示对一个二进制位取反。

异或运算符(xor):符号为^,表示若两个二进制位不相同,则结果为1,否则为0

左移运算符m << n 表示把m左移n位,左移n位的时候,最左边的n位将被丢弃,同时在最右边补上n0,比如:

00001010<<2 = 00101000

右移运算符m >> n 表示把m右移n位,右移n位的时候,最右边的n位将被丢弃,同时在最左边补上n0,比如:

00001010>>2 = 00000010

我们可以让目标数字和一个数字做与运算

这个用户比较的数字必须只有一位是1其他位是0,这样就可以知道目标数字的这一位是否为0

所以用于比较的这个数字初始值为1,比较完后让1左移1位,这样就可以依次比较所有位是否为1

代码

function NumberOf1(n){    let flag = 1;    let count = 0;    while(flag){        if(flag & n){            count++;        }       flag = flag << 1;    }    return count;}

 法二:分析

 

 

转载于:https://www.cnblogs.com/QianDingwei/p/10923995.html

你可能感兴趣的文章
iOS resign code with App Store profile and post to AppStore
查看>>
python 表格操作
查看>>
LeetCode 84. Largest Rectangle in Histogram
查看>>
LeetCode Two Sum III - Data structure design
查看>>
session和xsrf
查看>>
Failed to initialize NVML: GPU access blocked by the operating system
查看>>
Ant Trip HDU - 3018(欧拉路的个数 + 并查集)
查看>>
wireshark问题现象分析
查看>>
【转载】JAVA IO 流的总结
查看>>
TensorFlow---image recognition--classify_image运行、文件说明与错误(路径)解决
查看>>
原生JavaScript封装Ajax
查看>>
2016年7月总结
查看>>
一周学会Mootools 1.4中文教程:(1)Dom选择器
查看>>
Cookie与Session
查看>>
配置redis外网可访问
查看>>
haproxy 配置https 同时技持443 80端口
查看>>
js正则备忘
查看>>
跟随大神实现简单的Vue框架
查看>>
Linux目录结构
查看>>
learning awk
查看>>