二进制的和(c#)

该博客介绍如何在C#中计算两个二进制字符串的和。通过从后向前遍历字符串,逐位相加并处理进位,最终得到结果。提供了解决方案的详细描述和代码链接。
摘要由CSDN通过智能技术生成

问题描述

给定两个二进制字符串,返回二进制字符串的和。


示例

  • 示例1

Input: a = “11”, b = “1”
Output: “100”

  • 示例2

Input: a = “1010”, b = “1011”
Output: “10101”


解决方案描述

  1. 判断这两个字符串是否都为空,如果都为空,则返回空串。如果其中一个为空,则返回非空的字符串。
  2. 从后往前循环遍历字符串a,和字符串b,进位变量初始化为0,执行下面的操作,
    a,b字符串的当前的字符值转换为整数并相加,并且加上进位变量,赋值给sum变量。
    如果sum变量值大于等于2,则将进位变量设为1,当前值为sum-2的值,转化为字符串并且和结果字符串结合。
    否则,则将进位变量设为0,当前值为sum的值,转化为字符串并且和结果字符串结合。
  3. 字符串a没遍历完,则从后向前遍历a,执行下面的操作
    a字符串的当前的字符值转换为整数加上进位变量,赋值给sum变量
    如果sum变量值大于等于2,则将进位变量设为1,当前值为sum-2的值,转化为字符串并且和结果字符串结合。
    否则,则将进位变量设为0,当前值为sum的值,转化为字符串并且和结果字符串结合。
    1.字符串b没遍历完,则从后向前遍历b,执
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值