【每日算法C#】二进制求和 LeetCode

方法介绍

cs 复制代码
    public string AddBinary(string a, string b)
    {
        int i = a.Length - 1;
        int j = b.Length - 1;
        int carry = 0;
        string result = "";
        while (i >= 0 || j >= 0 || carry > 0)
        {
            int sum = carry;
            if (i >= 0)
            {
                sum += a[i] - '0';
                i--;
            }
            if (j >= 0)
            {
                sum += b[j] - '0';
                j--;
            }
            result = (sum % 2) + result;
            carry = sum / 2;
        }
        return result;
    }

这段代码实现的是两个二进制字符串的加法,返回它们的和(仍为二进制字符串)。以下是核心逻辑的总结:

  1. 输入 :两个二进制字符串 ab (例如 "1010""1011" )。
  2. 输出 :它们的二进制和(例如 "10101" )。
  3. 算法
    • 从字符串的末尾(最低位)开始逐位相加。
    • 使用 carry 记录进位。
    • 每次计算当前位的和( sum ),并更新进位( carry = sum / 2 )。
    • 将当前位的值( sum % 2 )拼接到结果字符串的左侧。

隐式转换说明

代码中涉及以下隐式转换(由编译器自动完成):

1. 字符到整数的转换
cs 复制代码
sum += a[i] - '0';
  • a[i] 是一个字符( '0''1' )。
  • '0' 的 ASCII 值是 48'1'49
  • a[i] - '0' 通过减法将字符隐式转换为整数:
    • '0' - '0' = 0
    • '1' - '0' = 1
2. 整数到字符的转换
cs 复制代码
result = (sum % 2) + result;
  • sum % 2 的结果是 01 (整数)。
  • 在与字符串 result 拼接时,整数被隐式转换为字符:
    • 0'0'
    • 1'1'
3. 整数除法的截断
cs 复制代码
carry = sum / 2;
  • sum / 2 是整数除法,结果会被截断为整数:
    • sum = 2 ,则 carry = 1
    • sum = 1 ,则 carry = 0

关键点分析

  1. 字符与整数的转换

    • 通过 - '0' 将字符 '0' / '1' 转换为整数 0 / 1 ,是二进制字符串处理的常见技巧。
    • 反向转换(整数 → 字符)通过字符串拼接自动完成。
  2. 进位逻辑

    • sum 的范围是 012 (因为每位相加的最大值是 1 + 1 + 1 = 3 )。
    • sum % 2 得到当前位的值, sum / 2 得到进位值。
  3. 字符串拼接的方向

    • 结果是从最低位开始构建的,因此每次拼接在字符串的左侧result = (sum % 2) + result )。

示例演示

a = "1010" (十进制 10)和 b = "1011" (十进制 11)为例:

  1. 初始状态
    • i = 3 , j = 3 , carry = 0 , result = ""
  2. 逐步计算
    • 第一轮: sum = 0 + 0 + 1 = 1result = "1" , carry = 0
    • 第二轮: sum = 0 + 1 + 1 = 2result = "01" , carry = 1
    • 第三轮: sum = 1 + 0 + 0 = 1result = "101" , carry = 0
    • 第四轮: sum = 0 + 1 + 1 = 2result = "0101" , carry = 1
    • 第五轮: sum = 1result = "10101" , carry = 0
  3. 结果
    • "10101" (十进制 21)。

优化建议

  1. 使用 StringBuilder

    • 当前方法通过字符串拼接效率较低,建议改用 StringBuilderInsert(0, value) 方法。

    • 示例:

      cs 复制代码
      var sb = new StringBuilder();
      sb.Insert(0, sum % 2);
  2. 边界条件处理

    • 如果输入为空字符串,可以直接返回另一个字符串:csharp

      插入

      复制

      新建文件

      保存

      应用代码

      cs 复制代码
      if (string.IsNullOrEmpty(a)) return b;
      if (string.IsNullOrEmpty(b)) return a;

总结

  • 隐式转换:通过字符与整数的加减实现类型转换,是二进制字符串处理的核心技巧。
  • 算法效率 :时间复杂度为 O(n)n 是较长字符串的长度),但字符串拼接部分可以优化。
  • 适用场景:适用于任意长度的二进制字符串加法。
相关推荐
happygrilclh11 分钟前
高压高频电源的pid算法
算法
格林威17 分钟前
Baumer相机铸件气孔与缩松识别:提升铸造良品率的 6 个核心算法,附 OpenCV+Halcon 实战代码!
人工智能·opencv·算法·安全·计算机视觉·堡盟相机·baumer相机
葫三生24 分钟前
存在之思:三生原理与现象学对话可能?
数据库·人工智能·神经网络·算法·区块链
Evand J28 分钟前
【MATLAB例程】无人机三维路径规划|A*,RRT(快速随机树算法), APF(人工势场法)算法对比|可自定义起终点、障碍物坐标。附下载链接
算法·matlab·无人机·astar·路径规划·rrt·apf
有来技术36 分钟前
ASP.NET Core 权限管理系统(RBAC)设计与实现|vue3-element-admin .NET 后端
vue.js·后端·c#·asp.net·.net
少许极端42 分钟前
算法奇妙屋(二十七)-全排列与子集问题
算法·剪枝·回溯·递归
sali-tec43 分钟前
C# 基于OpenCv的视觉工作流-章20-仿射变换
图像处理·人工智能·opencv·算法·计算机视觉
u0109272711 小时前
实时数据流处理
开发语言·c++·算法
独自破碎E1 小时前
【滑动窗口+计数】LCR015找到字符串中所有字母异位词
数据结构·算法
Trouvaille ~1 小时前
【Linux】线程同步与互斥(一):线程互斥原理与mutex详解
linux·运维·服务器·c++·算法·线程·互斥锁