【LeeCode算法】第67题:二进制求和

目录

一、题目描述

二、初次解答

三、官方解法

四、总结


一、题目描述

二、初次解答

1. 思路:将a和b两个字符串转换成十进制,然后将相加的结果转换回文本的二进制。

2. 代码:

char* addBinary(char* a, char* b) {
    int a_len = strlen(a);
    int b_len = strlen(b);
    //将a和b的二进制转换为int十进制
    int value[2] = {0, 1};
    int aRet = 0, bRet = 0;
    for (int i = a_len - 1; i >= 0; --i) {
        aRet += value[a[i] - '0'] * pow(2, a_len - 1 - i);
    }
    for (int j = b_len - 1; j >= 0; --j) {
        bRet += value[b[j] - '0'] * pow(2, b_len - 1 - j);
    }
    //计算十进制之和,将结果转换为二进制并保存
    int Ret = aRet + bRet;
    if (Ret == 0) {
        return a;
    }
    int lenMax = (a_len > b_len)?a_len:b_len;
    char* ret = (char*)malloc(sizeof(char) * (lenMax + 2));
    ret[lenMax + 1] = '\0';
    char valuec[2] = {'0', '1'};
    int k = lenMax;
    for (; Ret != 0; --k) {
        ret[k] = valuec[Ret % 2];
        Ret /= 2;
    }
    if (k >= 0){
        return ret + 1;
    }
    return ret;
}

3. 缺陷:对于相加超过int范围的例子,就无法求解!

三、官方解法

1. 思路:将两个字符串反转,然后存放至目标数组的元素值为(a[i]+b[i]+进位值)%2,而进位值为(a[i]+b[i]+进位值)/2。最后,将目标数组再次反转即可。

2. 代码:

void reverse(char* s) {
    int len = strlen(s);
    for (int i = 0, j = len - 1; i < j; i++, j--){
        char temp = s[i];
        s[i] = s[j];
        s[j] = temp;
    }
}

char* addBinary(char* a, char* b) {
    reverse(a);
    reverse(b);
    int a_len = strlen(a), b_len = strlen(b);
    int lenMax = (a_len > b_len)?a_len:b_len;
    char* ret = (char*)malloc(sizeof(char) * (lenMax + 2));
    int flag = 0, len = 0;
    for (int i = 0; i < lenMax; ++i){
        flag += i < a_len ? (a[i] == '1') : 0;
        flag += i < b_len ? (b[i] == '1') : 0;
        ret[len++] = flag % 2  + '0';
        flag /= 2;
    }
    if (flag == 1){
        ret[len++] = '1';
    }
    ret[len] = '\0';
    reverse(ret);
    return ret;
    return a;
}

3. 优点:实现思想较为简单。

4. 缺点:①使用了三次反转,执行时间较长。②核心for循环中的语句很难想到这么精简的。

四、总结

当遇到反向操作时,可以尝试使用三次反转来完成。另外,对于位数不齐的情况,可以使用三元运算符来综合有位数和无位数的情况。例如,flag += i < a_len ? (a[i] == '1) : 0;就是先判定i是不是小于a的长度,如果是才进行访问,否则直接给0,避免了越界访问的错误。

  • 9
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
粒子群算法(Particle Swarm Optimization,PSO)和二进制粒子群算法(Binary Particle Swarm Optimization,BPSO)都是一种基于群体智能的优化算法,用于解决优化问。它们的主要区别在于粒子的表示方式和搜索空间。 1. 粒子群算法(PSO): - 粒子的表示方式:每个粒子由一组实数向量表示,其中每个维度代表一个问的解。 - 搜索空间:粒子在连续的解空间中进行搜索,可以处理实数型的优化问。 - 更新规则:每个粒子根据自身历史最优解和群体最优解进行位置更新,通过速度和位置的调整来搜索最优解。 2. 二进制粒子群算法(BPSO): - 粒子的表示方式:每个粒子由一组二进制位表示,其中每个位代表一个问的解的状态(0或1)。 - 搜索空间:粒子在离散的解空间中进行搜索,适用于处理离散型的优化问。 - 更新规则:每个粒子根据自身历史最优解和群体最优解进行位的翻转操作,通过改变位的状态来搜索最优解。 相比而言,二进制粒子群算法相对于粒子群算法具有以下优势: - 内存占用更小:由于二进制粒子群算法使用二进制位表示解,相比于实数向量表示的粒子群算法,所需的内存空间更小。 - 搜索效率更高:二进制粒子群算法在离散解空间中进行搜索,可以更快地找到最优解,节约搜索时间。 - 避免内存溢出问:当问规模较大时,粒子群算法可能会出现内存溢出问,而二进制粒子群算法可以避免这个问的发生。 因此,根据引用的研究结果,离散二进制粒子群算法在基于模型配电网故障诊断中的应用中,相比于其他算法(如HS-Tree、Boolean Algebra方法、遗传算法),具有更高的搜索效率,可以节约1/3~1/2的搜索时间,并且可以避免内存溢出问

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值