首页 > 其他 > 详细

Add Binary

时间:2014-11-10 23:07:32      阅读:368      评论:0      收藏:0      [点我收藏+]

Add Binary

 

Given two binary strings, return their sum (also a binary string).

For example,
a = "11"
b = "1"
Return "100".

 1 public class Solution {
 2     public String addBinary(String a, String b) {
 3         char num1[] = a.toCharArray();
 4         char num2[] = b.toCharArray();
 5         int result[] = new int[Math.max(a.length(), b.length()) + 1];//保存结果
 6         int i = num1.length - 1;
 7         int j = num2.length - 1;
 8         int k = result.length - 1;
 9         while(i >= 0 && j >= 0){
10             if(num1[i] == ‘1‘ && num2[j] == ‘1‘)
11                 result[k--] = 2;
12             else if(num1[i] == ‘0‘ && num2[j] == ‘0‘)
13                 result[k--] = 0;
14             else
15                 result[k--] = 1;
16             i--;
17             j--;
18         }//至少有一个计算完成
19         while(i >= 0){
20             result[k--] = num1[i--] - ‘0‘;
21         }
22         while(j >= 0)
23             result[k--] = num2[j--] - ‘0‘;
24         k = result.length - 1;
25         while(k > 0){
26             if(result[k] / 2 == 1)
27             {
28                 result[k - 1] += 1;
29                 result[k] %= 2;
30             }
31             k--;
32         }
33         String ret = "";
34         if(result[0] != 0){
35             for(i = 0; i < result.length; i++)
36                 ret += String .valueOf(result[i]);
37         }
38         else
39         {
40             for(i = 1; i < result.length; i++)
41                 ret += String .valueOf(result[i]);
42         }
43         return ret;
44     }
45 }

 

Add Binary

原文:http://www.cnblogs.com/luckygxf/p/4088284.html

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