IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> [剑指offer专项突击版-Java解法]剑指 Offer II 002. 二进制加法 -> 正文阅读

[数据结构与算法][剑指offer专项突击版-Java解法]剑指 Offer II 002. 二进制加法

剑指 Offer II 002. 二进制加法

题目描述

给定两个 01 字符串 ab ,请计算它们的和,并以二进制字符串的形式输出。

输入为 非空 字符串且只包含数字 10

示例?1:

输入: a = "11", b = "10"
输出: "101"
示例?2:

输入: a = "1010", b = "1011"
输出: "10101"
?

提示:

每个字符串仅由字符 '0' 或 '1' 组成。
1 <= a.length, b.length <= 10^4
字符串如果不是 "0" ,就都不含前导零。


思路解析

1.这就是大数相加的思路

2.和小时候计算加法一样,从右往左进行竖位相加

3.如果有进位,就加一,如果超过2,那就保留一个进位给下一次用

4.使用StringBuilder进行存储字符串

代码实现

class Solution {
    public String addBinary(String a, String b) {
        if("0".equals(a)&&"0".equals(b)) return "0";
        if("0".equals(a)||"0".equals(b)) return "0".equals(a)?b:a;
        boolean isAdd = false;
        char[] achars = a.toCharArray();
        char[] bchars = b.toCharArray(); 
        int la = achars.length-1;
        int lb = bchars.length-1;
        StringBuilder sb = new StringBuilder();
        while(la>=0&&lb>=0) {
            int ia = achars[la--]-'0';
            int ib = bchars[lb--]-'0';
            int iab = ia+ib;
            if(isAdd) {
                iab++;
                isAdd = false;
            }
            if(iab>=2) {
                iab-=2;
                isAdd = true;
            }
            sb.insert(0,iab);
        }
        while(la>=0) {
            int ia = achars[la--]-'0';
            if(isAdd) {
                ia++;
                isAdd = false;
            }
            if(ia>=2) {
                ia-=2;
                isAdd = true;
            }
            sb.insert(0,ia);
        }
        while(lb>=0) {
            int ib = bchars[lb--]-'0';
            if(isAdd) {
                ib++;
                isAdd = false;
            }
            if(ib>=2) {
                ib-=2;
                isAdd = true;
            }
            sb.insert(0,ib);
        }
        if(isAdd) sb.insert(0,1);
        return sb.toString();
    }
}

欢迎大佬们关注小弟的博客https://blog.csdn.net/qq_41522089

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-09-20 16:00:39  更:2021-09-20 16:02:15 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/19 10:04:28-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码