在C中打印二进制的ASCII字符值

时间:2013-09-15 23:31:50

标签: c

我是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个字节的顺序错误。任何使它以正确的顺序打印它的提示都会很棒!

谢谢!

2 个答案:

答案 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次。