当前位置: 首页 > article >正文

【蓝桥杯】每天一题,理解逻辑(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;

    }

};

在这里插入图片描述

时间复杂度:
在这里插入图片描述


http://www.kler.cn/a/592352.html

相关文章:

  • 【HarmonyOS Next之旅】DevEco Studio使用指南(五) -> 添加/删除Module
  • Pandas完全指南:数据处理与分析从入门到实战
  • Netty源码—1.服务端启动流程一
  • 武汉临空港开发区第七批区级非物质文化遗产代表性项目和第四批非遗传承人申报条件流程和材料时间
  • 大模型如何赋能安全防御?威胁检测与漏洞挖掘的“AI革命”
  • 基于java的ssm+JSP+MYSQL的高校四六级报名管理系统(含LW+PPT+源码+系统演示视频+安装说明)
  • 【UE5 PuerTS笔记】PuerTS安装
  • 深度解析 | Android 13 Launcher3分页指示器改造:横线变圆点实战指南
  • 在 Ubuntu 下通过 Docker 部署 Nginx+PHP-FPM 服务器
  • 华为鲲鹏ARM服务器安装Docker
  • MySql面试总结(三)
  • C#的List和DIctionary实现原理(手搓泛型类以及增删查改等功能)
  • ABAP SQL模糊查询日期年月日方法
  • 【MySQL】基本查询(表的增删查改+聚合函数)
  • 【新能源汽车“心脏”赋能:三电系统研发、测试与应用匹配的恒压恒流源技术秘籍】
  • 【k8s系列】Kubernetes ReplicaSet 原理机制与基础应用要点
  • 【QT 多线程示例】两种多线程实现方式
  • Redis 面试思路
  • 【算法day15】最接近的三数之和
  • Spring Boot 启动参数终极解析:如何优雅地控制你的应用?