我对我的程序有什么问题没有任何线索。我刚刚测试了在将这个“实验”添加到我的项目之前是否可以在至少一个控制台应用程序上使用它,你可以看到我失败了。
我创建了一个在数字基数之间转换数字的库(到目前为止,只有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;
}
答案 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
时二进制版本的工作原理。因此,请使用--j
和j = str_leg
,或j--
和j = strleg - 1
。
此外,处理模数部分 - 它将使您的程序更容易编写。