一、题目
函数原型:
int findComplement(int num)
二、思路将num的每一位取出来,取反后,乘以2的位次方,最终所有结果相加即可得到结果。
++如何取出num的每一位?++
num&1:取出num的最低位
num>>1:num算数右移1,最高位补符号位(由于num为整数,所以最高位补0)
++如何将取出的每一位取反?++
(num&1)^1:按位异或1,如果是0则取反为1,如果是1则取反为0
三、代码
cppint findComplement(int num) { int result=0; int i=0; while(num) { result+=pow(2,i)*(num&1^1); i++; num=num>>1; } return result; }
leetcode:476. 数字的补数
南林yan2023-11-16 17:34
相关推荐
算法鑫探4 小时前
闰年判断:C语言实战解析WBluuue4 小时前
数据结构与算法:康托展开、约瑟夫环、完美洗牌木子墨5165 小时前
LeetCode 热题 100 精讲 | 并查集篇:最长连续序列 · 岛屿数量 · 省份数量 · 冗余连接 · 等式方程的可满足性王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:均分纸牌EQUINOX16 小时前
2026年码蹄杯 本科院校赛道&青少年挑战赛道提高组初赛(省赛)第一场,个人题解萝卜小白6 小时前
算法实习Day04-MinerU2.5-proLiangwei Lin6 小时前
洛谷 P3133 [USACO16JAN] Radio Contact Gweixin_513449966 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结code_pgf6 小时前
Qwen2.5-VL 算法解析Code-keys7 小时前
Android Codec2 Filter 算法模块开发指南