二进制求和

题目来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/add-binary

给定两个二进制字符串,返回他们的和(用二进制表示)。

输入为非空字符串且只包含数字 1 和 0。

示例 1:

输入: a = "11", b = "1"
输出: "100"

示例 2:

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

解法:

class Solution {
    public String addBinary(String a, String b) {
        StringBuffer sb = new StringBuffer();
        int aIndex = a.length()-1;
        int bIndex = b.length()-1;
        //是否进位
        boolean flag = false;
        while(aIndex >= 0 || bIndex >= 0){
            char cA = '0';
            char cB = '0';
            if(aIndex >= 0)
                cA = a.charAt(aIndex);
            if(bIndex >= 0)
                cB = b.charAt(bIndex);
            if(cA == '1' && cB == '1'){
                if(flag){
                    sb.append("1");
                }else{
                    sb.append("0");
                }
                flag = true;
            }else if(cA == '0' && cB == '0'){
                if(flag){
                    sb.append("1");
                }else{
                    sb.append("0");
                }
                flag = false;
            }else{
                if(flag){
                    sb.append("0");
                    flag = true;
                }else{
                    sb.append("1");
                }
            }
            aIndex--;
            bIndex--;
        }
        if(flag){
            sb.append("1");
        }
        return sb.reverse().toString();
    }
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 给定两个二进制字符串,返回他们的和(用二进制表示)。 输入为非空字符串且只包含数字 1 和 0。 示例 1: 输入...
    FiveZM阅读 4,162评论 0 0
  • 题目 给定两个二进制字符串,返回他们的和(用二进制表示)。 输入为非空字符串且只包含数字 1 和 0。 示例 1:...
    LonnieQ阅读 1,274评论 0 0
  • 题目描述:给定两个二进制字符串,返回他们的和(用二进制表示)。 输入为非空字符串且只包含数字1和0。 字符相减其实...
    windUtterance阅读 1,526评论 0 0
  • 链接 https://leetcode-cn.com/problems/add-binary/descriptio...
    singed阅读 1,454评论 0 0
  • 中期借贷便利(Medium-term Lending Facility,MLF)。于2014年9月由中国人民银行创...
    孔祥子看天下阅读 5,778评论 0 0

友情链接更多精彩内容