C语言刷题系列——6.(递归)实现顺序输出整数
创始人
2024-03-12 15:30:51
0

递归实现顺序输出整数

  • ❄️一) 题目要求
    • ☃️1.函数接口定义:
    • ☃️2.裁判测试程序样例:
  • ❄️二) 非递归 解法
    • ☃️step1.统计位数
    • ☃️step2.循环,打印每一位
    • ☃️step3.实现
  • ❄️三) 递归 解法
    • ☃️step1.分析
    • ☃️step2.图解流程
    • ☃️step3.实现

)

❄️一) 题目要求

☃️1.函数接口定义:

void printdigits( int n );

函数printdigits应将n的每一位数字从高位到低位顺序打印出来,每位数字占一行。
在这里插入图片描述

☃️2.裁判测试程序样例:

#include void printdigits( int n );
int main()
{int n;scanf("%d", &n);printdigits(n);return 0;
}/* 你的代码将被嵌在这里 */

❄️二) 非递归 解法

☃️step1.统计位数

☃️step2.循环,打印每一位

☃️step3.实现

void printdigits(int n)
{int i = n,c=n;int count = 1;while (i /= 10){count++;}//统计位数for(int j = count;j>=1;j--){c=n;for(i = 0;ic /= 10;}c%=10;printf("%d\n",c);}
}

❄️三) 递归 解法

☃️step1.分析

输入一个数(比如12345),想要打印出每一位,可以拆解成:
先打印1,再用函数printdigits()对2345执行相同的操作
打印2,再用函数printdigits()对345执行相同的操作
打印3,再用函数printdigits()对45执行相同的操作
打印4,再用函数printdigits()直接打印最后一位5即可

☃️step2.图解流程

把step1倒过来看,
当递归到最后n<10的时候,直接打印出即可

由于要顺序打印(从高位向低位依次输出每一位数)

printdigits()括号里放n/10,使得每递归一次(从低位)少一位

在这里插入图片描述

☃️step3.实现

void printdigits(int n) 
{if (n < 10)printf("%d\n", n);else{printdigits(n / 10);printf("%d\n", n % 10);}
}

相关内容

热门资讯

公安部打掉黑灰产犯罪团伙200... 12月25日,公安部在京召开专题新闻发布会,通报公安部和国家金融监督管理总局联合部署开展金融领域“黑...
老年婚介服务引纠纷 成都金牛区... 追求爱情从来不是年轻人的专利,老年人也有权利去追求真爱。不过,不可只抱有美好期许,也要擦亮眼睛。近日...
国家医保局:长护险制度将从试点... 本报讯(中青报·中青网记者 刘昶荣)在日前浙江宁波召开的2025年全国长期护理保险高质量发展大会上,...
公安部发布金融领域“黑灰产”违... 12月25日,公安部在京召开专题新闻发布会,通报公安部和国家金融监督管理总局联合部署开展金融领域“黑...
国家发展改革委:加快推动交通运... 12月25日,国家发展改革委基础设施发展司刊发题为《加快构建现代化基础设施体系》的署名文章。文章指出...
国家发改委:优化收费公路政策 ... 每经AI快讯,据国家发改委官微消息,12月25日,国家发展改革委基础设施发展司发文称,深化重点领域改...
清华大学开展招生宣讲,发布招生... 红星新闻网12月25日讯12月24日,清华大学招生办公室发布声明。 声明称,近日,清华大学招生办接到...
公安部:立案查处金融领域“黑灰... 北京商报讯(记者 岳品瑜 董晗萱)12月25日,公安部召开新闻发布会,通报公安部和国家金融监督管理总...
感知山东| 胶州市开展“法律护... 为不断深化“陪伴成长”全环境立德树人品牌建设,近日,胶州市司法局李哥庄司法所联合镇宣传办,邀请市“蓝...