数字基数之间的转换出错了

时间:2016-06-17 03:42:32

标签: c++ binary hex

我对我的程序有什么问题没有任何线索。我刚刚测试了在将这个“实验”添加到我的项目之前是否可以在至少一个控制台应用程序上使用它,你可以看到我失败了。

我创建了一个在数字基数之间转换数字的库(到目前为止,只有B16或B2到十进制)。这是一个很大的解决方法,因为我无法理解如何管理模数和除法,但它似乎一直工作到一定程度。

我给了它一个0xFF,它把它当作0xFF0,结果是4,080。我给了它一个0x16,它把它当成了一个0x160,结果是352.显然发生了什么,但我不知道为什么会这样。至少到目前为止,问题只出在B16上,尽管B2确实给了我一些奇怪的错误。

这是代码(GNU编译器上的Code :: Blocks):

int bin_to_int(char char_digit){
    char_digit = toupper(char_digit);
         if (char_digit == '0') {return 0;}
    else if (char_digit == '1') {return 1;}
    else {return 2;}
}
int hex_to_int(char char_digit){
    char_digit = toupper(char_digit);
         if (char_digit == '0') {return 0;}
    else if (char_digit == '1') {return 1;}
    else if (char_digit == '2') {return 2;}
    else if (char_digit == '3') {return 3;}
    else if (char_digit == '4') {return 4;}
    else if (char_digit == '5') {return 5;}
    else if (char_digit == '6') {return 6;}
    else if (char_digit == '7') {return 7;}
    else if (char_digit == '8') {return 8;}
    else if (char_digit == '9') {return 9;}
    else if (char_digit == 'A') {return 10;}
    else if (char_digit == 'B') {return 11;}
    else if (char_digit == 'C') {return 12;}
    else if (char_digit == 'D') {return 13;}
    else if (char_digit == 'E') {return 14;}
    else if (char_digit == 'F') {return 15;}
    else {return 16;}
}
void conv_todec(int mode_base){
    if (mode_base == 16){std::cout << "\nHex to Dec function";}
    if (mode_base ==  2){std::cout << "\nBin to Dec function";}
    if (mode_base == 16){std::cout << "\nEnter a hex number: ";}
    if (mode_base ==  2){std::cout << "\nEnter a bin number: ";}
    std::string numb;
    std::cin >> numb;
    int str_leg = numb.length();
    int total = 0;
    for(int i(0);i<str_leg;i++){
        if (mode_base == 16){
            if (hex_to_int(numb[i]) == 16){func_erro();return;}}
        if (mode_base == 2){
            if (bin_to_int(numb[i]) == 2){func_erro();return;}}
        }
    int digits[str_leg] = {};
    int j = str_leg;
    for(int i(0);i<str_leg;i++){
    if (mode_base == 16) {digits[i] = hex_to_int(numb.at(i));}
    if (mode_base ==  2) {digits[i] = bin_to_int(numb.at(i));}
    if (mode_base == 16) {total += (digits[i] * power(mode_base,j--));}
    //Somehow the number never had the first digit claiming it as
    //either even or odd, so I tried pre-decrementing 'j' and it
    //worked for some reason I don't know either.
    if (mode_base ==  2) {total += (digits[i] * power(mode_base,--j));}}
    std::cout << "The result is: " << total << std::endl;
}

1 个答案:

答案 0 :(得分:0)

这一行:

 int j = str_leg;

表示对于十六进制FF,j将为2.这意味着稍后当您power(mode_base,j--)乘以第一个数字时,您将执行power(16, 2)(请记住j-- }表示取j的值,然后从j中减去一,但仍然使用原始值)。所以你将把第一个数字乘以256,你只想乘以16。

解决方案?将j作为较小的一个开始。

 int j = str_leg - 1;

注意,这就是为什么在使用--j时使用j时二进制版本的工作原理。因此,请使用--jj = str_leg,或j--j = strleg - 1

此外,处理模数部分 - 它将使您的程序更容易编写。