【蓝桥杯】每天一题,理解逻辑(4/90)【Leetcode 二进制求和】

题目描述

我们解析一下题目

  • 我们可以理解到两个主要信息
    • 给的是二进制的字符串
    • 返回他们的和

我们知道,十进制的加减法需要进位,例如:9+7=16是因为9+1之后进了一位,二进制也是如此,只不过十进制是逢10进1,二进制是逢2进1.

但是我们这里还需要注意两点

  • 题目给的是字符串
  • 返回的和也是字符串

算法原理[[leetCode]]

先说结论

  • 核心打法:
    • 字符串转数字
      结果数字再转字符

因为按照我们的习惯,加法喜欢从后面往前开始依次加

所以我们这里定义一个循环

{

  • 把每个字符串的最后一个字符转成数字
  • 用sum变量记录他们的和
  • push他们的和%2+'0'到一个新的字符串里面
  • 用carry记录他们的进位
    }

这里的carry的值可能会出现三种情况

  • 和有3中情况
    • 0:%2还是0,直接写入
    • 1:%2还是1,小于2,直接写入
    • 2:%2是0,但是要进位,写入0之后,用carry值记录他们的进位1
  • 然后在循环中carry的值给到sum,一直带着进位,直到遇到能写入的位置
  • 因为我们是从后往前依次加,但是结果是要从前往后读取的,所以我们要把结果反转一下

代码

复制代码
class Solution {

public:

    string addBinary(string a, string b) {

        int i=a.size()-1;

        int j=b.size()-1;

        int carry=0;

        string result;

        while(i>=0||j>=0||carry>0)

        {

            int sum=carry;

            if(i>=0)

            {

                sum+=a[i]-'0';

                i--;

            }

            if(j>=0)

            {

                sum+=b[j]-'0';

                j--;

            }

            result.push_back((sum%2)+'0');

            carry=sum/2;

        }

        reverse(result.begin(),result.end());

        return result;

    }

};

时间复杂度:

相关推荐
storyfull1 小时前
Excel(函数篇):IF函数、FREQUNCY函数、截取函数、文本处理函数、日期函数、常用函数详解
职场和发展·excel·学习方法
ChoSeitaku1 小时前
NO.42十六届蓝桥杯备战|数据结构|算法|时间复杂度|空间复杂度|STL(C++)
数据结构·算法·蓝桥杯
小卡皮巴拉4 小时前
【力扣刷题实战】无重复的最长字串
开发语言·c++·算法·leetcode·滑动窗口
半盏茶香4 小时前
启幕数据结构算法雅航新章,穿梭C++梦幻领域的探索之旅——二叉树序列构造探秘——堆的奥义与实现诗篇
android·数据结构·c++·python·算法·leetcode
奶油泡芙shi_caicai5 小时前
力扣题目汇总 使用贪心算法解决问题
算法·leetcode·贪心算法
Dream it possible!6 小时前
LeetCode 热题 100_跳跃游戏(78_55_中等_C++)(贪心算法)
c++·算法·leetcode·贪心算法
Geometry Fu6 小时前
好数 第十五届蓝桥杯大赛软件赛省赛C/C++ 大学 B 组
c语言·c++·蓝桥杯
每次的天空6 小时前
Android第三次面试总结(activity和线程池)
android·面试·职场和发展
你今天刷题了吗?7 小时前
蓝桥杯刷题day1:温度转换
职场和发展·蓝桥杯