当前位置: 首页 > news >正文

头歌C语言课程实验(递归函数、嵌套函数)

第1关:递归求阶乘数列

任务描述

题目描述:用递归求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字。

相关知识(略)
编程要求

请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入

一个整数n(1<=n<=20)

输出

输出表达式的值,占一行。

测试说明

样例输入:

5

样例输出:

153

提示:

因阶乘结果变化很快,所以输入数据不可太大。


开始你的任务吧,祝你成功!

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
long long solve(long long n)
{/*********Begin*********/long long i1 = 1, s = 1;while (i1 <= n){s = s * i1;i1++;}return s;/*********End**********/
}
int main(void)
{long long n;scanf("%lld", &n);long long ans = 0;for (long long i = 1; i <= n; i++)ans += solve(i);printf("%lld", ans);return 0;
}

第2关:递归实现输出一个整数的逆序

任务描述

题目描述:编写一个递归函数,将一个整数n逆序输出,比如,n = 12345,输出54321。 ####相关知识(略) ####编程要求 请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入

一个整数n输出

该整数的逆序。 ####测试说明 样例输入: 12345 样例输出:

54321


开始你的任务吧,祝你成功!

#include<stdio.h>
void solve(int n)
{printf("%d", (n%10));//取末位,1234再取/*********Begin*********/n = n / 10;//左移,1234/*********End**********/if (n > 0) solve(n);
}
int main(void)
{int n;scanf("%d",&n);solve(n);return 0;
}

第3关:将整数递归转换成字符串

任务描述

题目描述:用递归法将一个整数n转换成字符串。例如,输入n483,输出字符串 4 8 3,每个数字后面接一个空格用于隔开字符。 ####相关知识(略) ####编程要求 请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入

一个整数n 输出

相应的用空格隔开的数字字符。

特别注意:输出字符之间有空格

测试说明

样例输入:

483 样例输出:

4 8 3


开始你的任务吧,祝你成功!

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
void solve(int n)
{int temp = n % 10;//取3,8,4/*********Begin*********/n = n / 10;//48if(n > 0)solve(n);/*********End**********/if (n)printf(" %d", temp);elseprintf("%d", temp);
}
int main(void)
{int n;scanf("%d", &n);solve(n);return 0;
}

第4关:递归实现Ackman函数

任务描述

题目描述:编写一函数实现下列Ackman函数,其中mn为正整数

 Acm(m,n)= ⎩⎪⎪⎨⎪⎪⎧​n+1Acm(m−1,1)Acm(m−1,Acm(m,n−1))​ if m=0,n>0 if n=0,m>0 if n>0,m>0​

相关知识(略)
编程要求

请仔细阅读右侧代码,结合相关知识,在Begin-End区域内进行代码补充。 输入 一个两个整数 输出 输出表达式的值,占一行。 ####测试说明 样例输入: 1 1 样例输出: 3


开始你的任务吧,祝你成功!

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int Acm(int m, int n) {if (m == 0 && n > 0)/*********Begin*********/return n + 1;/*********End**********/else if (n == 0 && m > 0)/*********Begin*********/{return Acm(m - 1, 1);}/*********End**********/else/*********Begin*********/{return Acm(m - 1, Acm(m, n - 1));}/*********End**********/
}
int main(void)
{int m, n;scanf("%d%d", &m, &n);printf("%d", Acm(m, n));return 0;
}

http://www.lryc.cn/news/343872.html

相关文章:

  • 树莓派的几种登录方式、及登录失败解决方式
  • 数据库中视图的知识点
  • aardio封装库) 微软开源的js引擎(ChakraCore)
  • LeetCode-hot100题解—Day6
  • 【Linux】gcc/g++的使用
  • 2024-5-3学习笔记 虚拟继承原理
  • C语言什么是“野指针”?
  • LeetCode--所有质数、质数对
  • JavaScript异步编程——05-回调函数
  • JAVA基础之jsp标准标签
  • VM16激活码以及连接centos7过慢的问题
  • MySQL 迁移到 Oracle 需要注意的问题
  • 【数字经济】上市公司供应链数字化数据(2000-2022)
  • 通过AOP实现项目中业务服务降级功能
  • LeetCode:盛最多水的容器
  • 阿里云 OSS桶对象存储攻防
  • 外网禅道配置
  • MM模块学习一(供应商创建,物料类型的定义及功能)
  • 玩comfyui踩过的坑之使用ComfyUI_Custom_NODES_ALEKPET翻译组件问题
  • (类)偏特化Partial Specialization
  • TypeScript 基础学习笔记:interface 与 type 的异同
  • 【管理咨询宝藏95】SRM采购平台建设内部培训方案
  • 第七届机电、机器人与自动化国际会议(ICMRA 2024)即将召开!
  • 【智能楼宇秘籍】一网关多协议无缝对接BACnet+OPC+MQTT
  • leetCode68. 文本左右对齐
  • 搜狗输入法 PC端 v14.4.0.9307 去广告绿化版.
  • 【汇总】虚拟机网络不通(Xshell无法连接虚拟机)排查方法
  • C++开发基础之函数参数传递的几种类型
  • 使用memcache 和 redis 、 实现session 会话复制和保持
  • Tomcat 优化