67. Add Binary

来源:互联网 发布:大数据100g百度云 编辑:程序博客网 时间:2024/06/08 07:24
题意:就是把两个string的二进制数相加
难点:记得进位和按位相加就好
解法:
int len1 = a.Length - 1;//数组1的长度
            int len2 = b.Length - 1;//确定数组2的长度
            int carry = 0;//进位数
            char[] nums1 = a.ToCharArray();
            char[] nums2 = b.ToCharArray();
            string result = "";
            while (len1 >= 0 || len2 >= 0 || carry > 0)
            {
                int sum = 0;
                if (len1 >= 0)
                {
                    sum = sum + nums1[len1] - '0';//因为现在是char,实际上取的是数字对应的ASCLL码,要取数字得减去起始ascii码值转为对应值
                }
                if (len2 >= 0)
                {
                    sum = sum + nums2[len2] - '0';
                }
                sum = sum + carry;//当前非个位数=上一位的位数和+进位数
                carry = (int)sum / 2;//满2进1
                sum = sum % 2;//原数位归0
                result = sum.ToString() + result;
                len1--;
                len2--;
            }
            return result;

原创粉丝点击