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




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

我的代码

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

#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 @ 2023-10-18 23:12  最爱丁珰  阅读(20)  评论(0编辑  收藏  举报