当前位置: 首页 > news >正文

每日一题之二进制中1的个数

二进制中1的个数

问题描述:

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

科普一下有符号数的三种表示:原码、反码和补码,可能有时候遗忘了。
真值:带有符号位的机器数(一个数在计算机中的二进制表示形式,机器数是带符号的,计算机用一个数的最高位存放符号,0表示正数,1表示负数)对应的真正数值。

  • 原码:符号位加上真值的绝对值。
  • 反码:正数的反码是它本身,负数的反码对其原码逐位取反,符号位除外。
  • 补码:正数的补码是它本身,负数的补码等于反码+1,符号位除外。

负数的补码是能够和其相反数相加通过溢出从而使计算机内计算结果变为0的二进制码。比如 1 + ( − 1 ) = 0 1+(-1)=0 1+(1)=0
借鉴的解题思路:
方法1:循环按位比较法
(1)遍历二进制的32位,通过移位0-31次实现;
(2)将移位后的1与数字进行位与运算,结尾为1就记录一次。
补充知识:Python按位与操作

Python按位与操作是一种位运算操作,它用于对二进制数位进行操作。在Python中使用按位与符号“&”来进行运算,对两个二进制数的每一个数位进行比较,只有当两个对应数位都为1时,结果才为1,否则为0。
Python中 >> 和 << 都是位运算,<<是左移,>>是右移。x << 1是将x的二进制表示左移一位,相当于原数x乘2。比如整数4在二进制下是100,4<<1左移1位变成1000(二进制),结果是8。同理,>>是右移,右移1位相当于除以2。

主要用途:对二进制表示的数字进行处理。
按位与操作的特点:
1、当两个操作数的对应的二进制位都为1时,结果为1。
2、当两个操作数的对应的二进制位只要有一个为0时,结果为0。
3、按位与操作还可以用于清零特定的位数。例如,如果将1左移n个二进制位,得到的结果是只有第n个二进制位是1,其余都是0的数,那么对任意一个二进制数进行按位与操作,只有第n个二进制位上的数字会被保留下来,其余的数字都会被清零。

def NumberOf1(n: int)->int:res = 0# 遍历32位for i in range(32):# 按位比较;按位与操作if (n & (1 << i)) != 0:res += 1return res

方法2:位运算优化法
解题思路:
有一个性质 KaTeX parse error: Expected 'EOF', got '&' at position 2: n&̲(n-1),会将 n n n 的二进制中最低位由1变为0。
具体实现方法:
1.使用循环检查 n n n 是否为0;
2.不为0就与 n − 1 n-1 n1 做位与运算,去掉二进制最后一位的1,并统计次数。

def NumberOf1(n):res = 0# 负数转换if n < 0:n &= 0xffffffff# n = 0时,停止比较while n:n &= n-1res += 1return res
http://www.lryc.cn/news/131186.html

相关文章:

  • 8.17校招 内推 面经
  • VScode搭建Opencv(C++开发环境)
  • Redis高可用:哨兵机制(Redis Sentinel)详解
  • Hadoop小结(上)
  • ORA-600 ksuloget2 恢复----惜分飞
  • NLP的tokenization
  • 【宝藏系列】一文讲透C语言数组与指针的关系
  • Jenkins+Jmeter集成自动化接口测试并通过邮件发送测试报告
  • clickhouse入门
  • 中间件: ElasticSearch的安装与部署
  • LabVIEW模拟化学反应器的工作
  • Python基础语法入门(第二十三天)——正则表达式
  • 山西电力市场日前价格预测【2023-08-20】
  • C++中function,bind,lambda
  • 跟着美团学设计模式(感处)
  • 2023/8/19 小红书 Java 后台开发面经
  • 基于traccar快捷搭建gps轨迹应用
  • 【深度学习-图像识别】使用fastai对Caltech101数据集进行图像多分类(50行以内的代码就可达到很高准确率)
  • Debian10: 安装nut服务器(UPS)
  • 神经网络基础-神经网络补充概念-47-动量梯度下降法
  • C++11并发与多线程笔记(13) 补充知识、线程池浅谈、数量谈、总结
  • python高级基础
  • 使用线性回归模型优化权重:探索数据拟合的基础
  • 亿级短视频,如何架构?
  • jenkins pipeline方式一键部署github项目
  • Vue 项目搭建
  • 【NetCore】09-中间件
  • 机器学习深度学习——BERT(来自transformer的双向编码器表示)
  • Datawhale Django后端开发入门 Vscode TASK02 Admin管理员、外键的使用
  • 【ES5和ES6】数组遍历的各种方法集合