力扣67 二进制求和 C语言

题目

给你两个二进制字符串 ab ,以二进制字符串的形式返回它们的和。

示例 1:

复制代码
输入:a = "11", b = "1"
输出:"100"

示例 2:

复制代码
输入:a = "1010", b = "1011"
输出:"10101"

思路

二进制求和需要考虑进位以及把两个数对齐的操作。官方题解中是将两个字符串反转,这样从低下标开始相加其实就是实际的加法过程了。对于进位问题,我原本想的是设一个变量 flag ,然后考虑 a[i] + b[i] + flag 对应的情况,官方题解中以 carry 表示进位,那么每一位的结果实际上是 (carry + a[i] + b[i])%2 ,不需要用 if 进行判断,进位就是 (carry + a[i] + b[i])/2,还挺妙的。如果最后进位不为 0 的话要在末尾加一个 1 ,最后反转结果得到最终答案。 官方题解的代码写的非常简洁,学到了反转字符串和 fmax()函数。

代码

复制代码
void reserve(char* s) {
    int len = strlen(s);
    for (int i = 0; i < len / 2; i++) {
        char t = s[i];
        s[i] = s[len - i - 1], s[len - i - 1] = t;
    }
}

char* addBinary(char* a, char* b) {
    reserve(a);
    reserve(b);

    int len_a = strlen(a), len_b = strlen(b);
    int n = fmax(len_a, len_b), carry = 0, len = 0;
    char* ans = (char*)malloc(sizeof(char) * (n + 2));
    for (int i = 0; i < n; ++i) {
        carry += i < len_a ? (a[i] == '1') : 0;
        carry += i < len_b ? (b[i] == '1') : 0;
        ans[len++] = carry % 2 + '0';
        carry /= 2;
    }

    if (carry) {
        ans[len++] = '1';
    }
    ans[len] = '\0';
    reserve(ans);

    return ans;
}
相关推荐
自信的小螺丝钉4 小时前
Leetcode 146. LRU 缓存 哈希表 + 双向链表
leetcode·缓存·散列表
古译汉书5 小时前
嵌入式铁头山羊STM32-各章节详细笔记-查阅传送门
数据结构·笔记·stm32·单片机·嵌入式硬件·个人开发
超级大福宝5 小时前
使用 LLVM 16.0.4 编译 MiBench 中的 patricia遇到的 rpc 库问题
c语言·c++
橘颂TA6 小时前
【数据结构】解锁数据结构:通往高效编程的密钥
数据结构
闭着眼睛学算法8 小时前
【华为OD机考正在更新】2025年双机位A卷真题【完全原创题解 | 详细考点分类 | 不断更新题目 | 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·javascript·c++·python·算法·华为od
麦麦在写代码9 小时前
动态内存管理 干货2
c语言
say_fall10 小时前
C语言底层学习(2.指针与数组的关系与应用)(超详细)
c语言·开发语言·学习
祐言QAQ10 小时前
(超详细,于25年更新版) VMware 虚拟机安装以及Linux系统—CentOS 7 部署教程
linux·运维·服务器·c语言·物联网·计算机网络·centos
Ziyoung10 小时前
【探究】C语言-类型转换问题
c语言
LeaderSheepH10 小时前
常见的排序算法
数据结构·算法·排序算法