我是C的新手,对于作业,我必须打印最多5个ASCII字符组合的8位二进制表示,即。 D3%= 01000100 00110011 00100101.
这是我的代码:
void ascii_to_binary(int * option_stats, char * ascii)
{
int i, j, num_value, count, binary[40], length, space=0; /* binary array length of 40 as */
length = strlen(ascii); /* 5*8 bit characters is 40 */
count = 8;
pos = 0
printf("Binary representation: ");
for (i = 0; i < length; i++)
{
num_value = ascii[i];
while(count > 0)
{
if((num_value%2) == 0)
{
binary[pos] = 0;
num_value = num_value/2;
count--;
pos++;
}
else
{
binary[pos] = 1;
num_value = num_value/2;
count--;
pos++;
}
}
count = 8; /*resets loop counter*/
}
for(j = pos-1; j >= 0; j--)
{
printf("%d", binary[j]);
space++;
if(space == 8)
{
printf(" "); /*white space between bytes*/
}
}
read_rest_of_line(); /*used as part of the larger program as a whole,
please ignore*/
}
我输入的ASCII字符是从一个单独的函数传递的,代码如下:
void run_ascii_binary(void)
{
char input[MAX_STRING_INPUT + EXTRA_SPACES], ascii;
int option_stats;
printf("ASCII to Binary Generator\n");
printf("-------------------------\n");
printf("Enter a String (1-5 characters): ");
if (fgets(input, MAX_STRING_INPUT+EXTRA_SPACES, stdin) != NULL)
{
sscanf(input, "%s", &ascii);
}
ascii_to_binary(&option_stats, &ascii);
}
我的问题是打印实际的二进制文件。
我得到的输出是:00100101 11001100 01000100,其中第1个字节和第3个字节的顺序错误。任何使它以正确的顺序打印它的提示都会很棒!
谢谢!
答案 0 :(得分:2)
ascii
对于5 char
和\0
来说必须足够大。
char ascii[5+1];
...
sscanf(input, "%5s", &ascii);
初始化option_stats
int option_stats = 0;
取消注释length = strlen(ascii);
。它被前一行未经评论的评论所评论。
@LtWorf是正确的,OP应该正好循环8次。
// while(num_value > 0) {
int bit;
int counti = count; /// see below
for (i=8; i-- > 0; ) {
此外,这些位从最不重要到最重要的累积,但您想要将它们显示为最小到最少。因此,以相反的顺序将它们累积在字符串中。
// In two places
// binary[count] = ...
binary[counti] = ...
还有其他方法可以清理代码,但这些是5个主要问题。
答案 1 :(得分:1)
while(num_value > 0)
这是错误的,char也可能是否定的。你最好只迭代8次。