力扣 面试题 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;
}
相关推荐
LDR0063 小时前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
Luminous.4 小时前
C语言--day30
c语言·开发语言
玖玥拾4 小时前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
謓泽5 小时前
C语言不是语法,是通往机器的地图。
c语言·开发语言
不会C语言的男孩5 小时前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言
2601_951643886 小时前
C语言长文整理,关键字和数据类型
c语言·数据类型·关键字·嵌入式开发·格式化输出
想吃火锅10057 小时前
【leetcode】121.买卖股票的最佳时机js/c++
算法·leetcode·职场和发展
m0_547486668 小时前
《C#语言程序设计与实践》 全套PPT课件
c语言·c#·c语言程序设计
✎ ﹏梦醒͜ღ҉繁华落℘9 小时前
编程基础 --高内聚,低耦合
c语言·单片机
凌波粒9 小时前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode