67.Add Binary(Easy)

Given two binary strings, return their sum (also a binary string).
给两个二进制的字符串,返回它们的和

For example

a = "11"
b = "1"
Return "100"

My Solution

(Java) Version 1 Time: 4ms:

  这个其实没有太复杂的原理,基本上只要是字符串表示数都是大数运算的套路,先把字符串逆序,然后高位补0,然后用循环逐位相加,对进位的情况进行处理,然后就得到结果了,复杂的是进位的几种情况的处理

public class Solution {
    public String addBinary(String a, String b) {
        StringBuffer s1 = new StringBuffer(a);
        StringBuffer s2 = new StringBuffer(b);
        int index_a = s1.length(),index_b = s2.length(),index = 0;
        s1.reverse();s2.reverse();
        if(index_a>index_b){
            index = index_a;
            for(int i = index_b;i

(Java) Version 2 Time: 4ms (By lianglinMan):

  这个思路号称是3ms但是实测是5ms,不过思路也是挺有意思的,先加,然后再做进位处理,比我的这种方式显然要简洁多了

public class Solution {
    public String addBinary(String a, String b) {
        int len1 = a.length(), len2 = b.length(),end1 = len1,end2 = len2;
        int maxLen = Math.max(len1,len2);
        int size = 0;
        int[] binarys = new int[maxLen + 1];
        while(size <= maxLen){
            if(size < len1) {
                binarys[size] += a.charAt(--end1) - '0';
            }
            if(size < len2) {
                binarys[size] += b.charAt(--end2) - '0';
            }
            if(binarys[size] >= 2){
                binarys[size] %= 2;
                binarys[size + 1] = 1;
            }
            size++;
        }

       StringBuffer buffer = new StringBuffer();
       if(binarys[maxLen] == 1){
           buffer.append(1);
       }
       for(int i = maxLen - 1; i >=0; i--){
           buffer.append(binarys[i]);
       }
       return buffer.toString();
    }
}

你可能感兴趣的:(67.Add Binary(Easy))