C语言 十进制数转化为二进制数

如题所述

#include
<stdio.h>
void
main()
{
int
a;
scanf(\"%d\",&a);//输入一个10进制数。
int
result=0;//存储a的二进制结果。
int
p=1;//p=1表示个位数
do
{
int
b=a%2;//b是余数,第一个余数是二进制的个位。
result=result+p*b;
p=p*10;//*10表示下个是10位数。
a=a/2;
}while(a);
printf(\"\\n%d\\n\",result);
}
程序在vc6.0下编译通过可以直接用,你自己看看吧,思路是a%2的结果是二进制的个位数,(a/2)%2的结果是二进制的十位数所以p扩大10倍,以后依次类推。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2020-07-28
代码如下:
#include<stdio.h>
int main(void){
int n,i,c=0,s[25];//定义数组用于按正确顺序打印
scanf("%d",&n);
for(i=n;i;i/=2){//通过变量i进行除2求余
s[c]=i%2;//注意要用余数
c+=1;
}
for(c-=1;c>=0;c-=1){//这时c先不减1会输出超大的负数
printf("%d",s[c]);
}
return 0;
}本回答被提问者采纳
第2个回答  2021-03-15

第3个回答  2019-06-26
思路:十进制整数转换为二进制整数采用"除2取余,逆序排列"法。即用2整除十进制整数,可以得到一个商和余数;再用2去除商,又会得到一个商和余数,如此进行,直到商为0时为止,然后把先得到的余数作为二进制数的低位有效位,后得到的余数作为二进制数的高位有效位,依次排列起来。
参考代码:
#include "stdio.h"
void fun(int n){
if(n==0) return;
fun(n/2);
printf("%d",n%2);
}
int main() {
int n;
scanf("%d",&n);
fun(n);
return 0;
}
/*
运行结果:例如求10的2进制
10
1010
*/

相关了解……

你可能感兴趣的内容

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