ACM队的队花C小+经常抱怨:“C语言中的格式输出中有十六、十、八进制输出,然而却没有二进制输出,哎,真遗憾!谁能帮我写一个程序实现输入一个十进制数n,输出它的二进制数呀?”
难道你不想帮帮她吗?^_^
- 输入
- 输入有多个数据,数据以EOF结束;每个数据ni(0<=ni<=1000010000)用空格隔开;
(温馨提示:EOF即是一个文件的结束标志;while(scanf("%d",&n)!=EOF){})
- 输出
- 输出有多行,每行对应一个十进制数ni的二进制数;
注意:输出的二进制去掉任何一个多余的0;
- 样例输入
-
0 1 2 10
- 样例输出
-
0 1 10 1010
-
解题思路:
-
当N为零时,直接输出零。当N不为来零时,将N除以2,每除一次得到的余数存放在数组中,然后再将数组倒序输出。
-
程序代码:
-
#include<stdio.h> #include<string.h> int main() { int n,i; int a[100]; while(scanf("%d",&n)!=EOF) { memset(a,0,sizeof(a)); if(n==0) printf("0\n"); else { i=0; while(n) { a[i]=n%2; n/=2; i++; } for(i=i-1;i>=0;i--) printf("%d",a[i]); } printf("\n"); } return 0; }
时间: 2024-12-22 00:21:14