力扣 面试题 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;
}
相关推荐
言存几秒前
力扣热题283 移动零
数据结构·算法·leetcode
AI科技星37 分钟前
《全域数学/数术工坊》体系总览
c语言·开发语言·汇编·electron·概率论
啦啦啦~~~3301 小时前
【装机工具】电脑重装系统!office安装管理软件!一键自动化下载、安装、部署Office的办公增强工具
运维·c语言·windows·自动化·电脑
LDR0061 小时前
宠物电器供电革新:USB-C PD标准化,重塑30-65W设备体验
c语言·开发语言·宠物
lpl3129055091 小时前
skynet 共享数据项目级应用
服务器·c语言·lua
洛水水2 小时前
【力扣100题】80.寻找旋转排序数组中的最小值
数据结构·算法·leetcode
redaijufeng2 小时前
为什么选择显式类型初始化而非auto推导
c语言
洛水水2 小时前
【力扣100题】82.有效的括号
c++·算法·leetcode
legend050709ComeON3 小时前
常见面试题-leetcode
数据结构·算法·leetcode
Lsk_Smion3 小时前
力扣实训 _ [207].课程表/图论
数据结构·leetcode·图论