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

(位运算) 剑指 Offer 15. 二进制中1的个数 ——【Leetcode每日一题】

❓ 剑指 Offer 15. 二进制中1的个数

难度:简单

编写一个函数,输入是一个无符号整数(以二进制串的形式),返回其二进制表达式中数字位数为 ‘1’ 的个数(也被称为 汉明重量).)。

提示

  • 请注意,在某些语言(如 Java)中,没有无符号整数类型。在这种情况下,输入和输出都将被指定为有符号整数类型,并且不应影响您的实现,因为无论整数是有符号的还是无符号的,其内部的二进制表示形式都是相同的。
  • 在 Java 中,编译器使用 二进制补码 记法来表示有符号整数。因此,在上面的 示例 3 中,输入表示有符号整数 -3

示例 1:

输入:n = 11 (控制台输入 00000000000000000000000000001011)
输出:3
解释:输入的二进制串 00000000000000000000000000001011 中,共有三位为 ‘1’。

示例 2:

输入:n = 128 (控制台输入 00000000000000000000000010000000)
输出:1
解释:输入的二进制串 00000000000000000000000010000000 中,共有一位为 ‘1’。

示例 3:

输入:n = 4294967293 (控制台输入 11111111111111111111111111111101,部分语言中 n = -3)
输出:31
解释:输入的二进制串 11111111111111111111111111111101 中,共有 31 位为 ‘1’。

提示

  • 输入必须是长度为 32 的 二进制串

注意:本题与 191. 位1的个数 相同。

💡思路:

基础知识必知:一篇文章搞懂位运算!!!

n&(n-1) 位运算可以将 n 的位级表示中最低的那一位 1 设置为 0。不断将 1 设置为 0,直到 n 为 0。
在这里插入图片描述

🍁代码:(C++、Java)

C++

class Solution {
public:int hammingWeight(uint32_t n) {int ans = 0;while(n != 0){n &= (n - 1);ans++;}return ans;}
};

Java

public class Solution {// you need to treat n as an unsigned valuepublic int hammingWeight(int n) {int ans = 0;while(n != 0){n &= (n - 1);ans++;}return ans;}
}

🚀 运行结果:

在这里插入图片描述

🕔 复杂度分析:

  • 时间复杂度 O ( l o g n ) O(logn) O(logn),循环次数等于 n 的二进制位中 1的个数,最坏情况下n` 的二进制位全部为 1。我们需要循环 O ( l o g n ) O(logn) O(logn) 次。。
  • 空间复杂度 O ( n ) O(n) O(n),我们只需要常数的空间保存若干变量。

题目来源:力扣。

放弃一件事很容易,每天能坚持一件事一定很酷,一起每日一题吧!
关注我LeetCode主页 / CSDN—力扣专栏,每日更新!

注: 如有不足,欢迎指正!

http://www.lryc.cn/news/155133.html

相关文章:

  • 基于SSM的新能源汽车在线租赁系统
  • CTF 代码审计之绕过过滤的空白字符
  • 【Vue】 Vue3 安装说明,适合小白新手
  • 电脑提示“系统找不到指定的文件”怎么办?
  • 向openssl中添加一个最简单的算法
  • 自己公司开发的ERP系统,怎么对接京东,淘宝等这些电商平台?
  • 联想集团财报不及华尔街预期,财务业绩恐将继续恶化
  • 计网基础面试题
  • 设置Linux CentOS7桥接模式连网
  • Mysql底层数据结构为什么选择B+树
  • R语言列操作函数
  • 【Unity】VS Code 没有自动补全 MonoBehaviour 的方法
  • 计算机竞赛 基于深度学习的人脸性别年龄识别 - 图像识别 opencv
  • 大厂面试 | 百度一面,顶不住
  • c++线程
  • 【Docker】02-安装mysql
  • JAVA每日小知识(关于excel下载时插入和stream流遍历优化)
  • 阿里后端开发:抽象建模经典案例
  • 【车载以太网测试从入门到精通】——DoIP BootLoader刷写测试(含CAPL源码)
  • RK开发板的USB连接(Ubuntu)
  • Redis-Cluster集群的部署(详细步骤)
  • Vulnhub: Hogwarts: Bellatrix靶机
  • 机器学习(吴恩达第一课)
  • 固定资产管理怎么改革
  • 【js】防抖和节流的使用场景和区别:
  • Blazor前后端框架Known-V1.2.14
  • 港陆证券:五日线破位怎么看?
  • 睿趣科技:抖音小店多久可以做起来
  • onnx 模型切割掉conv后面的节点,设置输出层名称和最后节点名称一致,设置输出层shape和输出节点一致.
  • 泛型的学习