字符串(3)_二进制求和_高精度加法

个人主页:C++忠实粉丝
欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 C++忠实粉丝 原创

字符串(3)_二进制求和_高精度加法

收录于专栏【经典算法练习
本专栏旨在分享学习算法的一点学习笔记,欢迎大家在评论区交流讨论💌

目录

[1. 题目链接](#1. 题目链接)

[2. 题目描述](#2. 题目描述)

[3. 解法](#3. 解法)

算法思路:

代码展示:


1. 题目链接

OJ链接 : 二进制求和https://blog.csdn.net/wer24_25/article/details/142949685?spm=1001.2014.3001.5502

2. 题目描述

给你两个二进制字符串 ab ,以二进制字符串的形式返回它们的和。

示例 1:

复制代码
输入:a = "11", b = "1"
输出:"100"

示例 2:

复制代码
输入:a = "1010", b = "1011"
输出:"10101"

提示:

  • 1 <= a.length, b.length <= 104
  • ab 仅由字符 '0''1' 组成
  • 字符串如果不是 "0" ,就不含前导零

3. 解法

算法思路:

模拟十进制的大数相加的过程:

模拟十进制中我们列竖式计算两个数之和的过程, 但是这里是二进制的求和, 我们不是逢十进一, 而是逢二进一.

代码展示:

cpp 复制代码
class Solution {
public:
    string addBinary(string a, string b) 
    {
        string ret;
        int n1 = a.size() - 1, n2 = b.size() - 1, t = 0;
        while(n1 >= 0 || n2 >= 0 || t)
        {
            if(n1 >= 0) t += a[n1--] - '0';
            if(n2 >= 0) t += b[n2--] - '0';
            ret += t % 2 + '0';
            t /= 2;
        }
        reverse(ret.begin(), ret.end());
        return ret;
    }
};

代码示例:

相关推荐
雪度娃娃几秒前
转向现代C++——保证const成员函数的线程安全性
开发语言·c++
坚果派·白晓明7 分钟前
[鸿蒙PC三方库移植适配] 使用 AtomCode + Skills 自动完成Protobuf鸿蒙化适配
c语言·c++·华为·harmonyos
dongf201912 分钟前
R语言KNN算法
算法·数据分析·r语言
原来是猿20 分钟前
深入理解 C++ unordered_map 与 unordered_set
开发语言·c++
满天星830357722 分钟前
【Qt】信号和槽 (一)(概述和基本使用)
开发语言·c++·qt
努力的章鱼bro25 分钟前
CUDA编程模型
c++·cuda
小O的算法实验室33 分钟前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习
8Qi839 分钟前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
地平线开发者39 分钟前
从 INT64 Div 算子约束到 Cast 修复全流程
算法
2601_9611940240 分钟前
教资科三美术考什么|初中高中美术题型考点和模板资料
leetcode·elasticsearch·职场和发展·蓝桥杯·pat考试·lucene