实验10-9 十进制转换二进制 (15分)
本题要求实现一个函数,将正整数n转换为二进制后输出。
函数接口定义:
void dectobin( int n );
函数dectobin应在一行中打印出二进制的n。建议用递归实现。
裁判测试程序样例:
#include <stdio.h>
void dectobin( int n );
int main()
{
int n;
scanf("%d", &n);
dectobin(n);
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
10
输出样例:
1010
void dectobin( int n )
{
if(n==0)printf("0");
else if(n==1)printf("1");
else {
dectobin(n/2);//这里需要从根本意义上理解递归函数的调用
//在此处就返回到dectobin(n/2)的函数体计算
//等一层一层剥开后最后n/2剩下的为1或0然后依次打印又回头打印上一层的
//每次除于2数就少一位就相当于十位数除于10
printf("%d",n%2);
}
}