Add binary 两个String形式二进制数相加

**两个字符串形式的二进制数相加
例如 “11”+“1”=“100”**
分析 需要对每个字符串取出单个的的数值相加,判断是2,1,0 分别进行取余和进位相加操作
a+b=c=2:c%2=0是结果,进位为1
1:结果是1,进位为0;
0:结果是0,进位为0;
public String addBinary(String a, String b) {
int i=a.length()-1,j=b.length()-1;
StringBuilder s=new StringBuilder();
int temp=0;
int tag=0;//进位标志
while(i>=0||j>=0){
temp=tag;
if(i>=0)temp+=a.charAt(i--)-'0';
if(j>=0)temp+=b.charAt(j--)-'0';
s.insert(0,(char)(temp%2+'0'));//插到零位
tag=temp/2;
}
if(tag==1)
s.insert(0,(char)(tag+'0'));
return s.toString();
}

为什么(char)(tag+’0’)这里必须进行char的强转
这里 tag+’0’=49是整形。因为0在ascii中对应的是48,所以会进行转换后相加为49,需要强转成char型。
‘1’+‘0’=49+48=97 对于char型的ascii码中值都会转成int型相加减

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值