-4

我认为我的 vs 代码中存在一些问题即使在编写了正确的代码之后它也给我错误的结果在我编写的几乎每一秒代码中我都得到了不确定的结果请帮我解决这个问题,请检查运行此代码在你的机器里......

#include <iostream>
using namespace std;
int main()
{

    char a[30];
    cout << "enter the hexadecimal";
    cin >> a;
    int i = 0, c, digit, decimal = 0, p = 1;
    while (a[i] != '\0') {
        i++;
    }
    for (int j = i; j >= 0; j--) {
        c = a[j];
        if (c >= 48 && c <= 57) {
            digit = c - 48;
        }
        else if (c >= 97 && c <= 112) {
            digit = c - 87;
        }
        decimal += digit * p;
        p *= 8;
    }
    cout << "\ndecimal is " << decimal;
    return 0;
}

在输入十六进制请仅输入小字母时,我没有考虑大写字母

要检查十六进制到十进制,请使用此站点https://www.rapidtables.com/convert/number/hex-to-decimal.html?x=146

4

1 回答 1

1

代码有几个问题,但我认为主要的问题是当它应该是 16 时,你将 p 乘以 8(因为十六进制是 base-16,而不是 base-8)。

您还应该注意无效的输入。例如,如果有人输入了无效的字母“j”会怎样?

此外,当您计算字符串的初始长度时,您将i使用 '\0' 值设置为数组的位置,因此当您开始处理输入时,a[i]为 0 并导致使用未初始化的变量(digit尚未分配了一个值,这与之前的“无效输入”问题有关)。

顺便说一句,我还会在比较中使用字符而不是 ASCII 代码,这样更容易看到您要查找的内容:

    if (c >= '0' && c <= '9') {
        digit = c - '0';
    }

等等...

于 2021-04-11T20:29:17.070 回答