3

整数を 32 ビット バイナリに変換するプログラムを作成しています。問題は出力にあります - それは逆になります。

#include <stdio.h>

int main() {
    long number, binary, num2;

    printf("Enter an integer: ");
    scanf("%ld", &number);

    for (num2 = (number * 2) / 2; num2 > 0; num2 /= 2) {
        binary = num2 % 2;
        printf("%ld", binary);
    }
    putchar('\n');
    return 0;
}

したがって、「6」を入力すると、011 と表示され、110 でなければなりません。

また、残りの '0' を出力するにはどうすればよいですか? したがって、この場合の出力全体は次のようになります。

00000000 00000000 00000000 00000110 
4

6 に答える 6

2

右から数字を計算するため、出力には右端の数字が最初に表示されます。ビットマスクを使用して左から開始し、ビットを変更する可能性のある値を符号なしに変換しない方法を次に示します。

#include <stdio.h>
#include <limits.h>

int main()
{
    long number;
    if ( 1 != scanf("%ld", &number) )
        return 1;

    // sign bit  (cannot use 1L left-shift as that causes UB)
    putchar( '0' + (number < 0) );

    // value bits
    for (long bit = 1L << (CHAR_BIT * sizeof number - 2); bit; bit >>= 1)
        putchar( '0' + !!(number & bit) );

    putchar('\n');
}
于 2015-03-16T00:25:52.100 に答える
0

これには、再帰関数を使用する方がはるかに簡単です。

#include <stdio.h>
#include <stdint.h>

void printInBinary(long num, int bit)
{
   if ( bit >= 8*sizeof(num) )
   {
      return;
   }

   printInBinary(num/2, bit+1);
   printf("%ld", num%2);

   if ( bit%8 == 0 )
   {
      printf(" ");
   }
   if ( bit == 0 )
   {
      printf("\n");
   }
}

int main()
{
   int y = 31;
   uint32_t x1 = (1 << y );
   uint32_t x2 = (1u << y );
   printf("x1: %u\n", x1);
   printInBinary(x1, 0);

   printf("x2: %u\n", x2);
   printInBinary(x2, 0);
}

出力:

x1: 2147483648
00000000 00000000 00000000 00000000 10000000 00000000 00000000 00000000
x2: 2147483648
00000000 00000000 00000000 00000000 10000000 00000000 00000000 00000000

PSの代わりにuint32_tforを使用すると、32 ビットの出力が得られます。numlong

于 2015-03-16T00:09:34.117 に答える
0

2 進数を出力する場合は、ビットを逆方向に出力する必要があります。これを見て:

6 (10):

6 / 2 = 3、レム => 0

3 / 2 = 1、レム => 1

1 / 2 = 0、レム => 1

したがって、6 (2) = 110

順方向に出力すると 011 になります。そのため、バイナリ ビットを変数に入れて保持し、最後に出力し直す必要があります。

これを試して

#include <stdio.h>
  int main(){
  long number, binary, num2;
  int i = 0, j;
  char num[100];

  printf("Enter an integer: ");
  scanf("%ld", &number);

  while (number != 0){
    num[i] = num2 % 2;
    number /= 2;
    i++;
  }
  for (j = 0; j < 32; j++) {
    if (j > i) {
      printf("0");
    }
    else {
      printf("%c", num[i]);
      i--
    }
  }
  printf("\n");
  return 0;
}
于 2015-03-15T23:55:04.653 に答える
-1

出力したい順序でビットを調べるだけです。unsigned long符号付き値のビットを符号ビットにシフトした結果が未定義であるため、シフトにキャストを使用しました。

    #include <stdio.h>
    #include <limits.h>

    int main() {
        long number = 0;
        int i;

        printf("Enter an integer: ");
        scanf("%ld", &number);
        for(i=0; i<sizeof(number)*CHAR_BIT; i++) {
            if (number < 0)
                printf ("1");
            else
                printf ("0");
            if ((i % CHAR_BIT) == CHAR_BIT - 1)
                printf (" ");
            number = (long)((unsigned long)(number) << 1);
        }
        printf("\n");
    return 0;
    }

プログラム出力:

Enter an integer: 6
00000000 00000000 00000000 00000110
于 2015-03-16T00:07:35.977 に答える
-1
#include <stdio.h>

int main(){
    // Assuming 32 bit architecture.
    unsigned long number;

    // Initialize a null-terminated char-array
    // of zeros (ASCII value 48).
    char binary[33] = {[0 ... 31] = 48, [32] = 0}; 

    printf("Enter an integer: ");
    scanf("%lu", &number);

    for(int i = 0; number > 0; ++i) {
        binary[31 - i] = number % 2;
        number /= 2;
    }
    printf("%s\n", binary);
    return 0;
}
于 2015-03-16T00:24:07.433 に答える