程度-ouc-sec 2021-05-03 03:54 采纳率: 100%
浏览 37
已采纳

进制转化中递归调用的实现。

麻烦各位大佬帮忙分析一下这个子函数内递归调用是怎么实现的。代码如下:

//进制转化,循环调用。 
#include<stdio.h>
#include<string.h>
void convto(char *s,int n,int b)
{
    char bit[]=("012345678ABCDEF");
    int len;
    if(n==0)
    {
        strcpy(s,"");   
        return;
    }
    convto(s,n/b,b);  //递归 ,这怎么解决循环的???? 
    len=strlen(s);
    s[len]=bit[n%b];
    s[len+1]='\0';
 } 
 void main()
 {
     char s[80];
     int i,base,old;
     printf("请输入十进制数:");
     scanf("%d",&old);
     printf("请输入转换的进制:");
     scanf("%d",&base);
     convto(s,old,base);
     printf("%s\n",s);
 }

展开全部

  • 写回答

6条回答 默认 最新

  • CSDN专家-三岁丫 2021-05-03 04:31
    关注

    写递归的一个重要条件就是终止条件,也就是 f == 0时,递归就会终止,进入回溯阶段

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    程度-ouc-sec 2021-05-03 10:30

    感谢,忘记了回溯👍

    回复
查看更多回答(5条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部