为什么我总是必须除以 49 才能得到二进制转换器 + cout 歧义的正确答案?

Why do I always have to divide by 49 to get the right answer for a binary converter + cout ambiguity?

本文关键字:cout 转换器 二进制 歧义 答案 为什么      更新时间:2023-10-16

我最近开始学习C++,如果我犯了一个愚蠢的错误,很抱歉......为什么我必须除以 49 才能得到正确答案?例如,如果我输入"1111"那么答案是 735 而不是 15。

所有数字都会发生这种情况,例如,如果我输入"10"那么答案是 98 而不是 2。另外,为什么我的cout显示不明确的值?我正在使用Visual Studio 2013。(请注意,除以 49 发生在最后一行)

void binaryToDecimal() {
string number = getNumber();
int sum = 0;
int factor = 1;
for (int i = number.length() - 1; i >= 0; i--) {
if (number.at(i) != '0' && number.at(i) != '1') {
cout << "Number is not in binary form" << endl;
system("pause");
exit(1);
}
if (number.at(i) == '1') {
sum += number.at(i) * factor;
}
factor *= 2;
}
cout << "'" << number << "' in binary is '" << sum / 49 << "'" << endl;
}

strings 中的字符存储在内部,与ints 不同。这个小代码片段希望能帮助你更好地理解这个神奇的数字。

#include <iostream>
#include <string>
using namespace std;
int main(void){
std::string test("1234");
for(size_t i = 0; i < test.size(); i++){
std::cout << static_cast<int>(test.at(i)) << std::endl;
}
return 0;
}

其输出为:

49
50
51
52

特别要注意的是,将字符串"1"强制转换为int的值为 49。

为了避免这种神奇的数字方法,您可能需要做以下两件事之一:

使用字符串进行整数转换,如boost::lexical_cast或"字符串流",首先将字符串转换为整数表示形式,然后进行处理。但是,这会更改逻辑,因为您现在使用一些不同的数学。

或者,如果你想保持逻辑基本相同,那么最简单的办法就是一旦你通过了输入阶段,就不要在内部处理char

using namespace std;
bool binaryToDecimal() {
string raw_input("101");//This would be your get_number function
int sum = 0;
int factor = 1;
for (size_t i = raw_input.length()-1; i > 0; i--) { //I think you also had an off by one error here
if (raw_input.at(i) != '0' && raw_input.at(i) != '1') {
cout << "Number is not in binary form" << endl;
return false;
}
if (raw_input.at(i) == '1') {
sum += factor; //Previously you had a completely unnecessary number.at(i) in here
}
factor *= 2;
}
cout << "'" << raw_input << "' in binary is '" << sum << "'" << endl; //No more magic number required now!
return true;
}

ASCII 中的数字被分配到代码点 0x30-0x39(或 48-57)中。當你將某物乘以'1'當然,它總是在結果中包含'1'術語,即49。您需要通过从字符中减去'0'来将'0''1'转换为整数值

另外,无需乘法,只需从左到右读取字符串并移位,它会快得多