实验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);
    }
}

2020/1/15
——By Suki

扫描二维码关注公众号,回复: 10814300 查看本文章
发布了29 篇原创文章 · 获赞 27 · 访问量 2952

猜你喜欢

转载自blog.csdn.net/Eumenides_Suki/article/details/103993904
今日推荐