我正在尝试将十进制转换为二进制,例如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';
}
}
非常感谢任何帮助!
答案 0 :(得分:4)
该值不是小数。计算机内存中的所有值都是二进制的。
您要做的是使用特定的基础将int转换为字符串。
有一个功能,它被称为itoa
。
http://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)
以下是将十进制数转换为二进制数的算法
您可以在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);
}
程序输出:
答案 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;
}