在C中将十进制转换为二进制

时间:2013-01-11 14:35:31

标签: c binary decimal

我正在尝试将十进制转换为二进制,例如192到11000000.我只需要一些简单的代码来执行此操作,但到目前为止我的代码不起作用:

void dectobin(int value, char* output)
{
    int i;
    output[5] = '\0';
    for (i = 4; i >= 0; --i, value >>= 1)
    {
        output[i] = (value & 1) + '0';
    }
}

非常感谢任何帮助!

16 个答案:

答案 0 :(得分:4)

该值不是小数。计算机内存中的所有值都是二进制的。

您要做的是使用特定的基础将int转换为字符串。 有一个功能,它被称为itoahttp://www.cplusplus.com/reference/cstdlib/itoa/

答案 1 :(得分:3)

首先192无法在4

中表示

192 = 1100 0000,需要最少8位。

这是一个简单的C program to convert Decimal number system to Binary number system

#include <stdio.h>  
#include <string.h>  

int main()  
{  
    long decimal, tempDecimal;  
    char binary[65];  
    int index = 0;  

    /* 
     * Reads decimal number from user 
     */  
    printf("Enter any decimal value : ");  
    scanf("%ld", &decimal);  

    /* Copies decimal value to temp variable */  
    tempDecimal = decimal;  

    while(tempDecimal!=0)  
    {  
        /* Finds decimal%2 and adds to the binary value */  
        binary[index] = (tempDecimal % 2) + '0';  

        tempDecimal /= 2;  
        index++;  
    }  
    binary[index] = '\0';  

    /* Reverse the binary value found */  
    strrev(binary);  

    printf("\nDecimal value = %ld\n", decimal);  
    printf("Binary value of decimal = %s", binary);  

    return 0;  
} 

答案 2 :(得分:2)

5位数不足以满足您的示例(192)。可能你应该增加output

答案 3 :(得分:1)

几天前,我正在寻找快速且便携式sprintf("%d", num)的方法。在页面itoa with GCC找到了此实现:

/**
 * C++ version 0.4 char* style "itoa":
 * Written by Lukás Chmela
 * Released under GPLv3.

 */
char* itoa(int value, char* result, int base) {
    // check that the base if valid
    if (base < 2 || base > 36) { *result = '\0'; return result; }

    char* ptr = result, *ptr1 = result, tmp_char;
    int tmp_value;

    do {
        tmp_value = value;
        value /= base;
        *ptr++ = "zyxwvutsrqponmlkjihgfedcba9876543210123456789abcdefghijklmnopqrstuvwxyz" [35 + (tmp_value - value * base)];
    } while ( value );

    // Apply negative sign
    if (tmp_value < 0) *ptr++ = '-';
    *ptr-- = '\0';
    while(ptr1 < ptr) {
        tmp_char = *ptr;
        *ptr--= *ptr1;
        *ptr1++ = tmp_char;
    }
    return result;
}

答案 4 :(得分:1)

以下是将十进制数转换为二进制数的算法

  • 将输入的十进制数除以2并存储余数。
  • 将商存储回输入数字变量。
  • 重复此过程,直到商变为零。
  • 等效二进制数将是上述过程中的余数 逆序。

您可以在http://www.techcrashcourse.com/2015/08/c-program-to-convert-decimal-number-binary.html

查看c程序

答案 5 :(得分:0)

看起来像这样,但要小心,你必须反转结果字符串: - )

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
char output[256]="";

int main()
{
int x= 192;
int n;
n = x;
int r;
do {
r = n % 2;
if (r == 1)
   strcat(output,"1");
else strcat(output,"0");
n = n / 2;
}
while (n > 0);

printf("%s\n",output);
}

答案 6 :(得分:0)

所以...你检查了代码的输出,以了解它为什么不起作用?

So iteration 1 of your loop:
value = 192
i = 4
output[i] = (11000000 & 1) + '0' = 0 + 48 = 48 (char `0`)

Iteration 2 of your loop:
value = 96
i = 3
output[i] = (1100000 & 1) + '0' = 0 + 48 = 48 (char `0`)

Iteration 3 of your loop:
value = 48
i = 2
output[i] = (110000 & 1) + '0' = 0 + 48 = 48 (char `0`)

Iteration 4 of your loop:
value = 24
i = 1
output[i] = (11000 & 1) + '0' = 0 + 48 = 48 (char `0`)

Iteration 5 of your loop:
value = 12
i = 0
output[i] = (1100 & 1) + '0' = 0 + 48 = 48 (char `0`)

Final string: "00000"  and you wanted: "11000000"

您的代码有什么问题吗?不。我也没有走得太远。将输出/循环更改为:

output[8] = '\0';
for (i = 7; i >= 0; --i, value >>= 1)

然后你会得到正确的结果。

我建议只是一种更通用的方法,你使用的是固定长度的字符串,它限制了一个certian长度的二进制数。您可能想要执行以下操作:

loop while number dividing down is > 0
count number of times we loop
malloc an array the correct length and be returned

答案 7 :(得分:0)

#include <stdio.h>
#include <stdlib.h>
void bin(int num) {
    int n = num;
    char *s = malloc(sizeof(int) * 8);
    int i, c = 0;
    printf("%d\n", num);

    for (i = sizeof(int) * 8 - 1; i >= 0; i--) {
        n = num >> i;
        *(s + c) = (n & 1) ? '1' : '0';
        c++;
    }
    *(s + c) = NULL;
    printf("%s", s); // or you can also return the string s and then free it whenever needed
}

int main(int argc, char *argv[]) {
    bin(atoi(argv[1]));
    return EXIT_SUCCESS;
}

答案 8 :(得分:0)

你也可以在函数下使用while循环。我只是在寻找我的解决方案,但我得到的解决方案并不合适,所以我相应地采用了实际方法(除了使用2直到得到0并将提醒存储在数组中)并打印数组的反向并{ {3}}

#include <stdio.h>

    int main()
    {
        long long int a,c;
        int i=0,count=0;
        char bol[10000];
        scanf("%lld", &a);
        c = a;
        while(a!=0)
        {
            bol[i] = a%2;
            a = a / 2;
            count++;
            i++;
        }
        if(c==0)
        {
            printf("0");
        }
        else
        {
            for(i=count-1; i>=0; i--)
            {
                printf("%d", bol[i]);
            }
        }
        printf("\n");
        return 0;
    }

答案 9 :(得分:0)

// C使用Stack

将Decimal转换为二进制的程序
#include<stdio.h>

#define max 100

int stack[max],top=-1,i,x;  


void push (int x)
{
  ++top;
  stack [top] = x;
}

int pop ()
{ 
   return stack[top];
}   


void  main()
{
  int num, total = 0,item;
  print f( "Please enter a decimal: ");
  scanf("%d",&num);
  while(num > 0)
  {  
    total = num % 2;
    push(total);
    num /= 2;
  }



 for(i=top;top>-1;top--)
 {     
     item = pop ();
     print f("%d",item);
 }

 }

答案 10 :(得分:0)

number=215
a=str(int(number//128>=1))+str(int(number%128>=64))+
str(int(((number%128)%64)>=32))+str(int((((number%12
8)%64)%32)>=16))+str(int(((((number%128)%64)%32)%16)>=8))
+str(int(((((((number%128)%64)%32)%16)%8)>=4)))
+str(int(((((((((number%128)%64)%32)%16)%8)%4)>=2))))
+str(int(((((((((((number%128)%64)%32)%16)%8)%4)%2)>=1)))))
print(a)

您也可以使用'if','else'语句来编写此代码。

答案 11 :(得分:0)

这是最简单的方法

#include <stdio.h>

void main()
{
    int n,i,j,sum=0;
    printf("Enter a Decimal number to convert it to binary : ");
    scanf("%d",&n);
    for(i=n,j=1;i>=1;j*=10,i/=2)
        sum+=(i%2)*j;
    printf("\n%d",sum);
}

答案 12 :(得分:0)

这是一个将数字从十进制转换为二进制的简单程序

#include <stdio.h>
#include <conio.h>
void decToBinary(int);

int main()
{
    int number;

    printf("Enter number to convert to binary: ");
    scanf("%d", &number);
    
    decToBinary(number);
  return 0;
}

void decToBinary(int num)
{
    if (num == 0)
    {
        return ;
    }

    decToBinary(num / 2);
    printf("%d", num % 2);
}

程序输出: Output of the Program

答案 13 :(得分:-1)

也许了解该算法可以让您编写或修改自己的代码以满足您的需要。我确实看到你没有足够的char数组长度来显示192的二进制值(你需要8位二进制数,但你的代码只给出5位二进制数字)

这里有一个page,可以清楚地解释算法。

我不是C / C ++程序员,所以这里是基于算法示例的C#代码贡献。

int I = 0;
int Q = 95;
string B = "";
while (Q != 0)
{
    Debug.Print(I.ToString());
    B += (Q%2);
    Q = Q/2;
    Debug.Print(Q.ToString());
    I++;
}

Debug.Print(B);

所有Debug.Print只是为了显示输出。

答案 14 :(得分:-1)

//decimal to binary converter
long int dec2bin(unsigned int decimal_number){
  if (decimal_number == 0)
    return 0;
  else
    return ((decimal_number%2) + 10 * dec2bin(decimal_number/2));
}

答案 15 :(得分:-2)

int main() 
{ 
 int n, c, k;
 printf("Enter an integer in decimal number system: ");
 scanf("%d", &n);
 printf("%d in binary number system is: ", n);
 for (c = n; c > 0; c = c/2) 
  {
   k = c % 2;//To
   k = (k > 0) ? printf("1") : printf("0");
  }
 getch();
 return 0; 
}