完整代码:三种写法
//递归法
#include<stdio.h>
void Bit(int n) {
if (n) {
Bit(n >> 1);
printf("%d", n & 1);
}
}
int main() {
int n;
while (scanf_s("%d", &n) != EOF) {
Bit(n);
putchar(‘\n‘);
}
return 0;
}
利用itoa(i ,num ,10 )函数
/*
i ---- 需要转换成字符串的数字
num ---- 转换后保存字符串的变量
10 ---- 转换数字的基数(即进制)。10就是说按10进制转换数字。还可以是2,8,16等等你喜欢的进制类型
返回值:指向num这个字符串的指针
*/
#include<stdio.h>
#include<stdlib.h>
int main() {
int n;
while (scanf("%d", &n) != EOF) {
char str[4000];
itoa(n, str, 2);
printf("%s\n", str);
}
return 0;
}
正常写法(雾
#include<stdio.h>
int main()
{
int i,j,k,l;
__int64 m[100];
while(scanf("%d",&i)!=EOF)
{
k=i;
for(j=0;j<100;j++)
{
m[j]=k%2;
k=k/2;
if(k==0) break;
}
for( ;j>=0;j--)
printf("%I64d",m[j]);
printf("\n");
}
return 0;
}
原文:https://www.cnblogs.com/RioTian/p/12766204.html