Leetcode 2220. 转换数字的最少位翻转次数
Published on 2022-06-14 09:50 in 暂未分类 with 萧海~

Leetcode 2220. 转换数字的最少位翻转次数

    在这里插入图片描述
    一次 位翻转 定义为将数字 x 二进制中的一个位进行 翻转 操作,即将 0 变成 1 ,或者将 1 变成 0 。

    • 比方说,x = 7 ,二进制表示为 111 ,我们可以选择任意一个位(包含没有显示的前导 0
      )并进行翻转。比方说我们可以翻转最右边一位得到 110 ,或者翻转右边起第二位得到 101 ,或者翻转右边起第五位(这一位是前导 0
      )得到 10111 等等。

    给你两个整数 start 和 goal ,请你返回将 start 转变成 goal 的 最少位翻转 次数。

    示例 1:

    输入:start = 10, goal = 7
    输出:3
    解释:107 的二进制表示分别为 10100111 。我们可以通过 3 步将 10 转变成 7
    - 翻转右边起第一位得到:1010 -> 1011
    - 翻转右边起第三位:1011 -> 1111
    - 翻转右边起第四位:1111 -> 0111
    我们无法在 3 步内将 10 转变成 7 。所以我们返回 3

    示例 2:

    输入:start = 3, goal = 4
    输出:3
    解释:34 的二进制表示分别为 011100 。我们可以通过 3 步将 3 转变成 4
    - 翻转右边起第一位:011 -> 010
    - 翻转右边起第二位:010 -> 000
    - 翻转右边起第三位:000 -> 100
    我们无法在 3 步内将 3 变成 4 。所以我们返回 3

    提示:

    • 0 <= start, goal <= 10^9

    Code:

    class Solution {
    public:
    string int2binarystring(int num)
    {
    string res;
    while(1)
    {
    res+=to_string(num%2);
    num=num/2;
    if(num==0)
    break;
    }
    reverse(res.begin(),res.end());
    return res;
    }
    int minBitFlips(int start, int goal) {
    string str1=int2binarystring(start);
    string str2=int2binarystring(goal);
    cout<<str1<<" "<<str2<<endl;
    if(str1.length()>str2.length())
    {
    int diff=str1.length()-str2.length();
    for(int i=0;i<(diff);i++)
    str2.insert(str2.begin(),'0');
    }
    else if(str1.length()<str2.length())
    {
    int diff=str2.length()-str1.length();
    for(int i=0;i<diff;i++)
    str1.insert(str1.begin(),'0');
    }
    int res=0;
    for(int i=0;i<str1.length();i++)
    {
    if(str1[i]!=str2[i])
    {
    res++;
    }
    }
    cout<<res<<endl;
    return res;
    }
    };
    posted @   萧海~  阅读(31)  评论(0编辑  收藏  举报
    相关博文:
    阅读排行:
    · 全程不用写代码,我用AI程序员写了一个飞机大战
    · DeepSeek 开源周回顾「GitHub 热点速览」
    · 记一次.NET内存居高不下排查解决与启示
    · 物流快递公司核心技术能力-地址解析分单基础技术分享
    · .NET10 - 预览版1新功能体验(一)
    点击右上角即可分享
    微信分享提示
    电磁波切换