计算机补码能够减法转加法的原因




可以想一下这道题(这里样例的二进制是补码)

我的代码

一些其他思路(特别是思路三,想想为啥)

#include <cmath>
#include <iostream>
using namespace std;

int main() {
    char n = 0;
    int power = 30, k = 0, ans = 0;
    cin >> n;
    char m = n;  // 用m存补码的符号位
    if (m == '1') {
        // 符号位为负
        for (int i = 1; i <= 31; i++) {
            cin >> n;
            if (n == '1')
                k = 0;
            else
                k = 1;
            ans += k * pow(2, power);
            power = power - 1;
        }
        cout << (-ans - 1) << endl;
    } else {
        // 符号位为正
        for (int i = 1; i <= 31; i++) {
            cin >> n;
            if (n == '1') ans = ans + pow(2, power);
            power = power - 1;
        }
        cout << ans << endl;
    }
    return 0;
}

#include <stdio.h>
#include <string.h>

int binaryToDecimal(char* sequence) {
    int length = strlen(sequence);
    int num = 0;
    int isNegative = (sequence[0] == '1');
    for (int i = 1; i < length; i++) {
        num = (num << 1) + (sequence[i] - '0');
    }
    if (isNegative) {
        num = num - (1 << (length - 1));
    }
    return num;
}

int main() {
    char sequence[33];
    scanf("%s", sequence);
    int num = binaryToDecimal(sequence);
    printf("%d", num);
    return 0;
}


posted @   最爱丁珰  阅读(50)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
历史上的今天:
2021-10-18 NOIP计划11题解
点击右上角即可分享
微信分享提示