C语言十进制转二进制

为什么输出是反的呢?

#include<stdio.h>
void main()
{
int a=0,b=0;
printf("\n 请输入一个数: \n");
scanf("%d",&a);
do
{

b=a%2;
printf("%d",b);
a=a/2;
}
while(a>0);

}
比如我输入2
它输出为01,反了一下
如何在转过来?
用数组我不只到给它要多大的空间,我不可能分配100000个空间吧
高手请指导一下..........................

呵呵这样做的确输出的是反过来的数
方法一:
可以利用数组顺序存储转换过程中依次得到每个数字位,
转换结束后再按相反的次序输出数组内容即可得到正确的结果。

方法二:
直接搞掂,这才叫强!!!
且看我如何强法!!

#include <stdio.h>
void trans(int x)
{
int a[30];//我算过了,1亿好像才29位的二进制,一般不用算
//这么大的数了吧~~
int i=0,rem;
do{
rem=x%2;x=x/2;
a[i]=rem;
i++;
}while(x!=0);//这个算法看你的代码知道你懂!:)
while(i>0)
printf("%d",a[--i]);
printf("\n");//这就是我的精华了,倒输出正确顺序的数~
}
void main()
{
int d;
printf("请输入一个十进制的正整数:\n");
do scanf("%d",&d);while(d<0);
trans(d);
}

我觉得楼主的水平也不差,
应该看得懂吧
我只是加了几句而已
加分哦:)
温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-12-24

十进制转二进制可以使用库函数itoa。

itoa函数原型:char*itoa(int value,char*string,int radix);

功能:将任意类型的数字转换为字符串。在<stdlib.h>中与之有相反功能的函数是atoi。

nt value 被转换的整数,char *string 转换后储存的字符数组,int radix 转换进制数,如2,8,10,16 进制等。


扩展资料:

方法

#include<stdio.h>

int main(void)

{ int i=0,n,a[32];

printf("请输入一个十进制整数.\n");

scanf("%d",&n);

while (n>0)

 {a[i]=n%2;

 i=i+1;

n=n/2;  }

printf("十进制整数转换为二进制数是:\n");

for(i--;i>=0;i--)

printf("%d",a[i]);

printf("\n");

return 0;}

十进制整数转换为二进制整数的方法:

十进制整数转换为二进制整数采用"除2取余,逆序排列"法。

具体做法是:用2去除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为零时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。

第2个回答  2008-03-12
把十进制变成二进制是反复取余除2的,这种方法没错,但是应该逆序读出0或1的序列,才是正确的。
语法正确,逻辑错误。不信在纸上算一下就能看出来了。
第3个回答  2008-03-12
#include<stdio.h>
void to_binary(unsigned long n);

int main(void)
{
unsigned long number;
printf("enter an integer :(q to quit)\n");
while(scanf("%ul",&number) == 1)
{
printf("binary equivalent :");
to_binary(number);
putchar('\n');
printf("enter an integer :(q to quit)\n");

}
printf("Done \n");
return 0;
}

void to_binary(unsigned long n)
{
int r;
r = n % 2;
if(n >= 2)
to_binary(n / 2);
putchar('0' + r);

return;
}
此为标准程序
#include<stdio.h>
#include<string.h>
int main(void)
{
int i = 0,m;
unsigned long n;
char a[64];
printf("please enter an integer(q to quit):\n");
while((scanf("%ul",&n)) == 1)
{
while(n >= 2)
{
a[i++] = (n % 2) + '0';
n /= 2;
}
a[i++] = '1';
a[i++] = '\0';
m = strlen(a);
for(i=m-1; i>=0; i--)
printf("%c",a[i]);
printf("\n");
printf("please enter an integer(q to quit):\n");
}
printf("Bye!\n");
return 0;
}
此为我自己做的,可以节省内存。
第4个回答  2019-12-30
使用库函数itoa。
itoa函数原型:char
*itoa(int
value,char*string,int
radix);
功能:将任意类型的数字转换为字符串。
其中int
value
被转换的整数,char
*string
转换后储存的字符数组,int
radix
转换进制数,如2,8,10,16
进制等。
参考代码:
#include <stdio.h>
#include<stdlib.h>
int main()
{
int n;
char a[100];
scanf("%d",&n);
itoa(n,a,2);//把十进制n转成2进制
printf("%s\n",a);
return 0;
}
/*
运行结果:把十进制的15转成2进制
15
1111
*/

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网