首页 > 其他 > 详细

[leetcode] 67. 二进制求和

时间:2018-07-25 00:29:15      阅读:301      评论:0      收藏:0      [点我收藏+]

67. 二进制求和

模拟加法运算

class Solution {
    public String addBinary(String a, String b) {
        int m = a.length();
        int n = b.length();
        a = new StringBuffer(a).reverse().toString();
        b = new StringBuffer(b).reverse().toString();

        int[] ans = new int[m + n];
        int i = 0;
        for (i = 0; i < a.length() && i < b.length(); i++) {
            ans[i] = a.charAt(i) - ‘0‘ + b.charAt(i) - ‘0‘;
        }
        if (i == a.length() && i < b.length()) {
            for (int j = i; j < b.length(); j++) {
                ans[j] = b.charAt(j) - ‘0‘;
            }
        }
        if (i == b.length() && i < a.length()) {
            for (int j = i; j < a.length(); j++) {
                ans[j] = a.charAt(j) - ‘0‘;
            }
        }

        // 处理进位
        int k = 0;
        while (k < m + n - 1) {
            ans[k + 1] += ans[k] / 2;
            ans[k] %= 2;
            k++;
        }
        int top = m + n - 1;
        while (ans[top] == 0 && top > 0) {
            top--;
        }
        String s = "";
        for (int j = top; j >= 0; j--) {
            s += ans[j];
        }
        return s;
    }
}

[leetcode] 67. 二进制求和

原文:https://www.cnblogs.com/acbingo/p/9363449.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!