力扣 面试题 05.06. 整数转换

思路:

牵扯到二进制数,基本上要考虑位运算符 ,相关知识可以见http://t.csdnimg.cn/fzts7

之前做过类似的题目,大致思路就是先用按位异或^找出不同位 ,再用n&(n-1)计算出不同位的个数 ,但是这道题有个小坑,就是极限了话,n刚好为int类型的最小值(即二进制数为1000......0000),此时n-1就会溢出。

就是A和B的二进制数刚好是1000......0000和0000......0000,此时n=A^B就是1000......0000,所以此时n再减1就溢出了,因此我们要考虑这个特殊情况

INT_MIN 代表int类型的最小值,即-2147483648

INT_MAX 代表int类型的最大值,即2147483647

定义INT_MIN 只能 INT_MIN = ( - INT_MAX) - 1

而不能 INT_MIN = - ( INT_MAX + 1) 因为这样就溢出最大值

其头文件为#include<limits.h>

复制代码
int convertInteger(int A, int B)
{
    int count=0;
    int n=A^B;
    while(n)
    {
        if(n==INT_MIN)   //如果是最小值
        {
            count++;     
            break;
        }
        n=n&(n-1);       //减去一个1的个数
        count++;         
    }
    return count;
}
相关推荐
羑悻的小杀马特5 分钟前
【动态规划篇】正则表达式与通配符:开启代码匹配的赛博奇幻之旅
c++·算法·leetcode·正则表达式
金刚狼885 分钟前
用atomic解决全局变量跨线程修改的问题
c语言
SuperByteMaster17 分钟前
callee和caller的区别
c语言
x_xbx18 分钟前
LeetCode:581. 最短无序连续子数组
算法·leetcode·排序算法
kkeeper~10 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
qq38624619612 小时前
更新补发第6天:7天学会C语言,每天5分钟,不需要基础
c语言·for循环·循环语句·while循环·do-while循环
罗超驿15 小时前
9.LeetCode 209. 长度最小的子数组 | 滑动窗口专题详解
java·算法·leetcode·面试
水蓝烟雨15 小时前
0135. 分发糖果
算法·leetcode
如竟没有火炬16 小时前
乘法表中第K小的数——二分
开发语言·数据结构·python·算法·leetcode·职场和发展·动态规划
张暮笛17 小时前
深入浅出:C语言中的“虚表分派”
c语言