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;
难点:记得进位和按位相加就好
解法:
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;
阅读全文
0 0
- [LeetCode]67.Add Binary
- LeetCode --- 67. Add Binary
- [Leetcode] 67. Add Binary
- [leetcode] 67.Add Binary
- 67. Add Binary
- 【leetcode】67. Add Binary
- 67. Add Binary
- [leetcode] 67.Add Binary
- [leetcode] 67. Add Binary
- 67. Add Binary
- 67. Add Binary
- 【Leetcode】67. Add Binary
- 67. Add Binary
- 67. Add Binary LeetCode
- 67. Add Binary
- 【LeetCode】67. Add Binary
- 67. Add Binary
- 67. Add Binary
- SpringMVC获取表单批量提交数据
- Django初识
- 三 树莓派开启samba服务
- jQuery源码总结
- 快排
- 67. Add Binary
- debian、ubuntu linux 源 汇总
- Spring Security(03)——核心类简介
- IP报文头
- USACO-Section1.2 Name That Number [其他]
- javascript中数据类型值的存储方式和位置
- PCA(主成分)分析及MATLAB实现
- jQuery选择器2
- 由阮一峰的博客想到的