一个以前的答案已经讨论与c[j] x = x % 2;问题和缺乏适当的字符转换。这就是说,我会指出一个不同的问题。请注意,这不是针对您的问题的具体解决方案,而是将其视为推荐。
对null终止符的位置进行硬编码不是一个好主意。事实上,它可能会导致一些不受欢迎的行为。想象一下,我创建长度为5。在内存的自动字符数组,它可能是这个样子:
Values = _ _ _ _ _
Index = 0 1 2 3 4
如果我是“1”,填充前三个指标“0”和“1” ,阵列可能看起来像这样:
Values = 1 0 1 _ _
Index = 0 1 2 3 4
比方说,我设置索引4包含空终止符。该阵列现在看起来像这样:
Values = 1 0 1 _ \0
Index = 0 1 2 3 4
请注意索引三是一个开放时隙?这不好。在C/C++中,自动数组默认包含垃圾数值。此外,通常通过从字符到字符迭代来打印字符串,直到遇到空终止符。
如果数组看起来像它在前面的例子中,打印它会产生一个奇怪的结果。它会打印1,0,1,然后是一个奇怪的垃圾值。
解决方法是在字符串结束后直接设置空终止符。在这种情况下,你希望你的阵列看起来像这样:
Values = 1 0 1 \0 _
Index = 0 1 2 3 4
指数4的值是无关紧要的,因为打印的功能,在阅读指数3中止。
下面是一个代码示例供参考:
#include
int main() {
const size_t length = 4;
char binary[length];
size_t i = 0;
while (i < length - 1) {
char c = getchar();
if (c == '0' || c == '1')
binary[i++] = c;
}
binary[i] = '\0';
puts(binary);
return 0;
}