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

Leetcode 144 位1的个数 | 只出现一次的数字

1 题目191. 位1的个数给定一个正整数n编写一个函数获取一个正整数的二进制形式并返回其二进制表达式中 设置位 的个数也被称为汉明重量。示例 1输入n 11输出3解释输入的二进制串1011中共有 3 个设置位。示例 2输入n 128输出1解释输入的二进制串10000000中共有 1 个设置位。示例 3输入n 2147483645输出30解释输入的二进制串1111111111111111111111111111101中共有 30 个设置位。提示1 n 231 - 12 代码实现cclass Solution { public: int hammingWeight(int n) { int ret 0 ; for (int i 0 ; i 32 ; i){ if (n (1 i )){ ret ; } } return ret ; } };js/** * param {number} n * return {number} */ var hammingWeight function(n) { let ret 0 ; for (let i 0 ; i 32 ; i){ if (n (1 i )){ ret ; } } return ret ; };思考我主要靠这题熟悉一下位运算的语法。题解第一步理解题目和整体框架这个函数的核心功能是统计一个 32 位无符号整数的二进制表示中数字 1 出现的次数汉明重量。我们先搭建最基础的类和函数框架// 定义一个解决方案类LeetCode 标准写法 class Solution { public: // 定义函数返回值是int类型参数n是要统计的32位整数 int hammingWeight(int n) { // 核心逻辑会写在这里 } };class SolutionLeetCode 固定的类名所有解题代码都放在这个类里。public函数的访问权限确保外部可以调用这个函数。int hammingWeight(int n)函数声明hammingWeight是函数名参数n是输入的整数返回值是 1 的个数整数。第二步初始化计数器接下来在函数内部定义一个变量用来记录 1 的个数class Solution { public: int hammingWeight(int n) { // 初始化计数器ret为0ret是result的缩写专门用来存1的个数 int ret 0 ; } };int ret 0;ret是计数器初始值必须为 0因为一开始还没统计到任何 1。第三步循环遍历 32 位二进制位因为题目明确是 32 位整数所以我们需要检查每一位从第 0 位到第 31 位class Solution { public: int hammingWeight(int n) { int ret 0 ; // 循环32次i从0到31对应二进制的第0位最低位到第31位最高位 for (int i 0 ; i 32 ; i){ // 每一位的检查逻辑写在这里 } } };for (int i 0 ; i 32 ; i)i 0从二进制最低位最右边开始检查。i 32因为是 32 位整数必须检查完所有位0~31 共 32 位。i每次检查下一位。第四步检查当前位是否为 1这是核心逻辑用位运算判断第i位是否为 1class Solution { public: int hammingWeight(int n) { int ret 0 ; for (int i 0 ; i 32 ; i){ // 关键位运算判断n的第i位是否为1 if (n (1 i )){ ret ; // 如果是1计数器加1 } } } };这里拆解两个关键位运算1 i把数字 1 向左移动i位生成一个 “只有第i位是 1其余位都是 0” 的数。比如i01 0 1二进制000...0001。比如i11 1 2二进制000...0010。比如i31 3 8二进制000...1000。n (1 i)按位与运算。只有当n的第i位是 1 时结果才不为 0否则结果为 0。举例如果n5二进制000...0101检查i05 1 0101 0001 0001 ≠ 0→ 第 0 位是 1ret加 1。检查i15 2 0101 0010 0000 0→ 第 1 位是 0不计数。检查i25 4 0101 0100 0100 ≠ 0→ 第 2 位是 1ret再加 1。第五步返回最终结果循环结束后ret就是 1 的总个数返回这个值class Solution { public: int hammingWeight(int n) { int ret 0 ; for (int i 0 ; i 32 ; i){ if (n (1 i )){ ret ; } } // 返回最终统计的1的个数 return ret ; } };完整代码 测试示例为了让你更直观理解我们加一个main函数测试#include iostream using namespace std; class Solution { public: int hammingWeight(int n) { int ret 0 ; for (int i 0 ; i 32 ; i){ if (n (1 i )){ ret ; } } return ret ; } }; int main() { Solution sol; // 测试用例1n5二进制0101预期结果2 int n1 5; cout n5的二进制中1的个数 sol.hammingWeight(n1) endl; // 测试用例2n0二进制全0预期结果0 int n2 0; cout n0的二进制中1的个数 sol.hammingWeight(n2) endl; // 测试用例3n3二进制0011预期结果2 int n3 3; cout n3的二进制中1的个数 sol.hammingWeight(n3) endl; return 0; }运行结果n5的二进制中1的个数2 n0的二进制中1的个数0 n3的二进制中1的个数2总结核心思路遍历 32 位整数的每一位用1 i定位第i位再用运算判断该位是否为 1统计总数。位运算关键1 i生成 “掩码”n 掩码仅保留第i位的数值非 0 则说明该位是 1。边界处理循环固定 32 次确保覆盖 32 位整数的所有位包括最高位的符号位。3 题目136. 只出现一次的数字给你一个非空整数数组nums除了某个元素只出现一次以外其余每个元素均出现两次。找出那个只出现了一次的元素。你必须设计并实现线性时间复杂度的算法来解决此问题且该算法只使用常量额外空间。示例 1 输入nums [2,2,1]输出1示例 2 输入nums [4,1,2,1,2]输出4示例 3 输入nums [1]输出1提示1 nums.length 3 * 104-3 * 104 nums[i] 3 * 104除了某个元素只出现一次以外其余每个元素均出现两次。4 代码实现cclass Solution { public: int singleNumber(vectorint nums) { int ret 0 ; for (auto e : nums){ ret ^ e ;} return ret ; } };js/** * param {number[]} nums * return {number} */ var singleNumber function(nums) { let ret 0 ; for (const e of nums){ ret ^ e ; } return ret ; };思考泪目。25年7月用java提交过现在毫无印象了曾经还用java写算法hhh...不过这题和位运算有什么关系啥意思和0异或异或得到的是啥a和0异或得到的是a吧a再和a异或就是0所以说两轮异或得到0一轮异或得到本身也就是就出现过一次的数妙啊我看题解的我自己不会写的hhh。5 小结非常水的一节也不能如此说位运算主要是一个思路和语法看了就知道的办法。不过我也是才做位运算的解法还没做到难的。坚持加油

相关文章:

Leetcode 144 位1的个数 | 只出现一次的数字

1 题目 191. 位1的个数 给定一个正整数 n,编写一个函数,获取一个正整数的二进制形式并返回其二进制表达式中 设置位 的个数(也被称为汉明重量)。 示例 1: 输入:n 11 输出:3 解释&#xff1…...

VS2019编译的QT程序,如何用windeployqt和Dependency Walker双工具精准‘瘦身’打包?

VS2019编译的QT程序:用windeployqt和Dependency Walker实现精准依赖分析与极简打包 在开发跨平台的QT应用程序时,打包发布往往是一个容易被忽视却又至关重要的环节。特别是当项目依赖多个大型第三方库(如VTK、OpenCV等)时&#xf…...

MCP23017 I²C端口扩展器原理与IPOL极性反转实战

1. MCP23017 IC端口扩展器深度技术解析 MCP23017是Microchip公司推出的16位IC总线可编程GPIO端口扩展器,广泛应用于STM32、ESP32、Raspberry Pi等嵌入式平台的外设资源扩展场景。其核心价值在于以极低的硬件开销(仅需2根IC信号线)实现16个双向…...

深入解析monaco-editor滚动条异常:从scrollBeyondLastLine配置到编辑器视口渲染优化

1. 为什么monaco-editor会出现多余的滚动条? 第一次使用monaco-editor时,很多开发者都会遇到这个奇怪的现象:明明编辑器内容很少,连容器高度的一半都没占满,右侧却莫名其妙出现了滚动条,拖动时还会显示大片…...

Qwen3-0.6B-FP8极速对话工具:Git版本控制智能助手

Qwen3-0.6B-FP8极速对话工具:Git版本控制智能助手 1. 引言 你有没有遇到过这样的情况:正在紧急修复线上 bug,突然发现代码冲突了,手忙脚乱地查文档、问同事,结果耽误了宝贵时间?或者刚接触 Git&#xff0…...

PHP项目中如何快速生成专业级二维码?Endroid QR Code终极解决方案

PHP项目中如何快速生成专业级二维码?Endroid QR Code终极解决方案 【免费下载链接】qr-code QR Code Generator 项目地址: https://gitcode.com/gh_mirrors/qr/qr-code 在PHP应用开发中,二维码生成功能已成为营销推广、支付集成、身份验证等场景的…...

用PyTorch实战PINN:手把手教你搞定Navier-Stokes方程逆问题(附完整代码)

用PyTorch实战PINN:从零构建Navier-Stokes方程求解器 在计算流体力学领域,Navier-Stokes方程的求解一直是工程师和科研人员面临的挑战。传统数值方法如有限体积法需要复杂的网格划分,而物理信息神经网络(PINN)提供了一种全新的无网格求解范式…...

避开Docker陷阱:Mac上正确安装Node Exporter的两种方法对比

Mac上高效部署Node Exporter的深度实践指南 在Mac环境下部署监控工具时,Node Exporter因其轻量级和全面的系统指标采集能力成为许多开发者的首选。但不同于Linux系统的一键式安装,Mac用户往往面临两种截然不同的安装路径选择——手动安装与Docker容器化部…...

告别手动字幕制作:OpenLRC让AI为你自动生成精准同步歌词

告别手动字幕制作:OpenLRC让AI为你自动生成精准同步歌词 【免费下载链接】openlrc Transcribe and translate voice into LRC file using Whisper and LLMs (GPT, Claude, et,al). 使用whisper和LLM(GPT,Claude等)来转录、翻译你的音频为字幕文件。 项…...

【图文教程】C盘满了怎么清理? | Win10/W11电脑系统C盘清理教程|远离C盘变红爆红 |10种清理C盘的安全方法 |C盘清理工具

当你打开电脑,系统不断弹出“C盘空间不足”的警告时,电脑运行明显变慢、软件卡顿、文件保存失败,甚至系统更新也无法安装。这时就该行动了! C盘满了怎么清理? 这 10种安全有效的清理方法,涵盖 Win10 / Win1…...

汇川中型PLC纯ST语言双轴同步设备程序

汇川中型plc+纯ST语言双轴同步设备,程序中没有使用任何库文件,纯原生codesys功能块。 非常适合初学入门者,三个虚拟驱动模拟虚主轴和两个伺服从轴,只要手里有汇川AM400,600,AC700,800即可实际运行该项目程序…...

小白必看!Holistic Tracking镜像快速入门:上传照片秒得全息骨骼

小白必看!Holistic Tracking镜像快速入门:上传照片秒得全息骨骼 1. 什么是Holistic Tracking? Holistic Tracking是一项革命性的人体感知技术,它能从一张普通照片中同时捕捉你的面部表情、手势动作和身体姿态。想象一下&#xf…...

快速部署AI头像生成器:Gradio界面一键使用,无需配置

快速部署AI头像生成器:Gradio界面一键使用,无需配置 1. 为什么你需要这个AI头像生成器? 在数字社交时代,一个精心设计的头像能显著提升个人或品牌的第一印象。但现实中,我们常面临这些困扰: 翻遍相册找不…...

万象熔炉丹青幻境打造个人品牌:快速生成Logo与视觉素材实战

万象熔炉丹青幻境打造个人品牌:快速生成Logo与视觉素材实战 1. 为什么个人品牌需要专业视觉设计 在当今数字化时代,视觉形象已经成为个人品牌不可或缺的一部分。无论是自由职业者、内容创作者还是小微企业主,一个专业的Logo和统一的视觉风格…...

ESP32+freeRTOS实战:从裸机开发到多任务协作的平滑过渡指南

ESP32freeRTOS实战:从裸机开发到多任务协作的平滑过渡指南 当你在ESP32上完成几个简单的LED闪烁和传感器读取项目后,可能会发现裸机开发的局限性越来越明显——那个经典的while(1)循环开始变得臃肿,各种延时函数阻塞了整个系统,而…...

Clawdbot整合Qwen3:32B实战体验:AI代理网关部署与聊天界面使用

Clawdbot整合Qwen3:32B实战体验:AI代理网关部署与聊天界面使用 1. 初识Clawdbot:AI代理网关的核心价值 在当今AI应用开发中,开发者经常面临一个共同挑战:如何高效管理和集成多个AI模型。Clawdbot的出现,正是为了解决…...

QNX系统线程优先级实战:如何避免嵌入式开发中的调度陷阱?

QNX线程优先级实战:嵌入式开发中的调度优化与陷阱规避 在嵌入式系统开发领域,QNX以其微内核架构和实时性能著称,而线程优先级调度机制正是其核心优势之一。然而,这也是一把双刃剑——不当的优先级设置可能导致系统性能下降、响应延…...

FRCRN Git仓库管理:代码版本控制与协作开发指南

FRCRN Git仓库管理:代码版本控制与协作开发指南 如果你对语音降噪技术感兴趣,特别是FRCRN这个效果不错的模型,并且想为它的开源项目贡献一份力量,那么这篇文章就是为你准备的。很多开发者有很好的想法,但一想到要参与…...

ftSwarm-Control:面向fischertechnik的轻量级分布式控制框架

1. ftSwarm-Control 项目概述ftSwarm-Control 是一个面向教育与创客场景的轻量级分布式控制框架,专为 fischertechnik(费舍尔技术)模块化机器人系统设计。其核心目标并非构建工业级冗余控制系统,而是通过低成本、易部署的网络化微…...

Qwen3-ASR-0.6B部署教程:Kubernetes集群中ASR服务编排实践

Qwen3-ASR-0.6B部署教程:Kubernetes集群中ASR服务编排实践 语音识别技术正在改变我们与设备交互的方式,但如何将强大的ASR模型高效部署到生产环境?本文将手把手教你如何在Kubernetes集群中部署Qwen3-ASR-0.6B模型,构建可扩展的语音…...

千问图像生成16Bit技术博文:BFloat16数值稳定性原理与溢出抑制机制

千问图像生成16Bit技术博文:BFloat16数值稳定性原理与溢出抑制机制 1. 引言:从“黑图”到“稳定出图”的技术跨越 如果你用过早期的AI图像生成工具,特别是那些基于FP16(半精度浮点数)推理的版本,很可能遇…...

嵌入式RTOS选型的工程决策方法论

1. 嵌入式开发中RTOS的工程适用性分析嵌入式系统开发中,是否引入实时操作系统(RTOS)并非技术先进性的简单标尺,而是一项需结合硬件资源约束、功能需求特性、可靠性目标与开发成本等多维度权衡的工程决策。在32位MCU普遍运行于48–…...

StructBERT模型在Ubuntu系统上的Docker部署指南

StructBERT模型在Ubuntu系统上的Docker部署指南 1. 引言 情感分析是自然语言处理中的一项重要任务,它能够帮助我们理解文本中蕴含的情感倾向。StructBERT情感分类-中文-通用-base模型基于11.5万条中文数据训练而成,能够准确识别文本的正向或负向情感。…...

Gemma-3-12b-it多模态教学应用:物理实验图解+原理讲解生成

Gemma-3-12b-it多模态教学应用:物理实验图解原理讲解生成 1. 工具概述 Gemma-3-12b-it是一款基于Google Gemma-3-12b-it大模型开发的多模态交互工具,专为本地化部署优化设计。它能够同时处理图片和文本输入,生成连贯、专业的回答&#xff0…...

SPIDebug:嵌入式SPI协议可视化调试工具

1. SPIDebug:嵌入式SPI总线活动可视化调试工具深度解析1.1 工程定位与核心价值SPIDebug并非传统意义上的功能型外设驱动库,而是一个专为嵌入式底层调试设计的SPI协议活动观测层(SPI Activity Observation Layer)。其本质是在标准S…...

Z-Image-GGUF快速部署:使用systemd替代supervisor的轻量级服务管理方案

Z-Image-GGUF快速部署:使用systemd替代supervisor的轻量级服务管理方案 1. 项目简介与部署思路 如果你正在寻找一个更轻量、更原生的服务管理方案来部署Z-Image-GGUF,那么systemd可能是比supervisor更好的选择。今天我要分享的就是如何用systemd来管理…...

嵌入式ADC滤波算法十大实战方案

1. ADC信号处理中的滤波算法工程实践指南在嵌入式系统中,模数转换器(ADC)采集的原始数据往往受到多种干扰源影响:电源纹波、PCB布线耦合噪声、传感器自身热噪声、电磁辐射干扰等。这些干扰表现为随机脉冲、周期性振荡或缓慢漂移&a…...

PmodCLS LCD模块命令流驱动设计与多协议适配

1. PmodCLS LCD模块驱动技术解析Digilent PmodCLS是一款基于字符型LCD的Pmod接口显示模块,采用标准HD44780兼容控制器架构,但通过UART、SPI或IC三种可选通信方式与主控MCU交互,而非传统8/4位并行总线。该模块内置字符生成ROM(CGRO…...

CSAPP AttackLab通关秘籍:从缓冲区溢出到ROP攻击实战(附完整代码)

CSAPP AttackLab深度实战:从栈溢出到ROP链构造的艺术 在计算机安全领域,理解软件漏洞的利用原理是防御体系构建的基础。CMU的CSAPP课程中的AttackLab实验,通过精心设计的五个渐进式挑战,带领学习者从基础的栈溢出攻击一直深入到现…...

嵌入式血氧饱和度算法BrainflowSpO2深度解析

1. BrainflowSpO2Algorithm 嵌入式血氧饱和度算法深度解析1.1 算法定位与工程价值BrainflowSpO2Algorithm 是一个面向嵌入式可穿戴设备的轻量级脉搏血氧饱和度(SpO₂)计算库,其核心设计目标并非替代临床级医疗设备,而是在资源受限…...