力扣 面试题 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;
}
相关推荐
Je1lyfish3 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
墨染千千秋5 小时前
C/C++ Keywords
c语言·c++
爱编码的小八嘎8 小时前
C语言完美演绎9-23
c语言
happymaker06268 小时前
简单LRU的实现(基于LinkedHashMap)
算法·leetcode·lru
普通网友9 小时前
《算法面试必刷:15 个高频 LeetCode 题(附代码)》
算法·leetcode·面试
_深海凉_9 小时前
LeetCode热题100-搜索二维矩阵
算法·leetcode·矩阵
我不是懒洋洋9 小时前
手写一个KMP算法:从原理到工程级实现
c语言
代码中介商9 小时前
C语言链表完全指南:从单节点到链表管理
c语言·算法·链表
『昊纸』℃10 小时前
C语言程序设计从入门到进阶【比特鹏哥c语言2023完整版视频教程】(c语言基础入
c语言·函数·常量·编程教程·变量作用域
凉、介11 小时前
Armv8-A virtualization 笔记 (一)
c语言·笔记·学习·嵌入式·虚拟化·hypervisor