C语言递归刷题(一)

目录

  • 走台阶
    • 题目
    • 思路
    • 代码
  • 西格玛
    • 题目
    • 思路
    • 代码
  • 用函数实现数的阶乘
    • 题目
    • 思路
    • 代码
  • digit
    • 题目
    • 思路
    • 代码
  • Hermite多项式
    • 题目
    • 思路
    • 代码
  • 排列数
    • 题目
    • 思路
    • 代码
  • 逆序输出
    • 题目
    • 思路
    • 代码
  • 结语

走台阶

题目

描述
小乐乐上课需要走n阶台阶,因为他腿比较长,所以每次可以选择走一阶或者走两阶,那么他一共有多少种走法?

输入描述:
输入包含一个整数n (1 ≤ n ≤ 30)
输出描述:
输出一个整数,即小乐乐可以走的方法数。
示例1
输入:
2
输出 :
2
示例2
输入:
10
输出:
89

思路

走台阶的这种就类似于斐波那契数列
f(n-1) + f(n-2)
从第三项开始,前两项的和等于第三项
这个范围比较小,可以使用斐波那契数列,递归的思想
结束条件: n < 3
多思考结束条件,递归自然就能写出来

代码

#include <stdio.h>int func(int n)
{if(n < 3)return n;elsereturn func(n-2)+func(n-1);
}
int main() 
{int n = 0;scanf("%d",&n);int ret = func(n);   printf("%d",ret);return 0;
}

西格玛

题目

描述
牛牛最近学会了一些简单的数学运算,例如
(1+2+3…+n-1+n) 请你帮他模拟一下这个运算。
输入描述:
输入仅一个正整数 n
输出描述:
请你计算

示例1
输入:
4
输出:
10

思路

例子给了,比如算前4项的和,1+2+3+4 = 10
那么结束条件是 n == 1,算到1就结束了
继续的条件是 n + func(n-1)

代码

#include <stdio.h>int func(int n)
{if(n == 1)return 1;elsereturn n + func(n-1);
}
int main() 
{int n = 0;scanf("%d",&n);int ret = func(n);printf("%d",ret);return 0;
}

用函数实现数的阶乘

题目

描述
编写一个函数 long long factorial(int n),用于计算 n 的阶乘。(要求使用递归实现)
输入描述:
键盘输入任意一个整数 n ,范围为 1 - 20
输出描述:
输出 n 的阶乘

示例1
输入:
5
输出:
120

思路

n*(n-1) * (n-2) …,比如:5 * 4 * 3 * 2 * 1,
结束条件是:n == 1,乘到1就结束
继续条件是:n * func(n-1)

代码

#include <iostream>
using namespace std;long long factorial(int n);int main() {int n;cin >> n;cout << factorial(n) << endl;return 0;
}
long long func(int n)
{if(n == 1)return n;elsereturn n*func(n-1);
}
long long factorial(int n) {scanf("%d",&n);long long ret = func(n);return ret;
}

digit

题目

描述
牛牛定义了一个函数 digit(x,i) ,表示分离出 x 的后 i 位的数字。

输入描述:
输入两个正整数 x 和 i
输出描述:
输出 x 的后 i 位数字

示例1
输入:
23908 3
输出:
908

思路

用 i 进行计数
结束条件是:i == 0
i 为 0 就得到了后i个数了
继续条件是 : x%10*(pow(10,t++)) + digit(x/10,–i,t)
用t进行计数,开始个位数是10的0次方,十位数是10的1次方,然后个位,十位,百位加起来就是要求的数

代码

#include <stdio.h>
#include<math.h>int digit(int x,int i,int t)
{if(i == 0)return 0;elsereturn x%10*(pow(10,t++)) + digit(x/10,--i,t);
}
int main() 
{int x = 0;int i = 0;scanf("%d %d",&x,&i);int count = 0;int t = 0;int ret = digit(x,i,t);printf("%d",ret);return 0;
}

Hermite多项式

题目

在这里插入图片描述

思路

这种题其实是水题,直接根据题目条件列出来就行了
就是满足上面的三个条件各写一个表达式
写三个if还不行,我也不是特别清楚,感觉是牛客要求要一个条件返回0的

代码

#include <stdio.h>int Hermite(int n,int x)
{if(n == 0)return 1;else if(n == 1)return n*2;else return 2*x*(Hermite(n-1,x)) - 2*(n-1)*(Hermite(n-2,x));
}
int main() 
{int n = 0;int x = 0;scanf("%d %d",&n,&x);int ret = Hermite(n,x);printf("%d",ret);return 0;
}
#include <stdio.h>int Hermite(int n,int x)
{if(n == 1)return n*2;if(n > 1)return 2*x*(Hermite(n-1,x)) - 2*(n-1)*(Hermite(n-2,x));if(n == 0)return 1;return 0;//三个条件都不满足返回0
}
int main() 
{int n = 0;int x = 0;scanf("%d %d",&n,&x);int ret = Hermite(n,x);printf("%d",ret);return 0;
}

排列数

题目

在这里插入图片描述

思路

这题是排列组合的公式
结束条件:

  • m > n 时,比如 m = 3,n = 2,那么210 = 0
  • m = 0时,结果是1
    m 是计算的次数
    n 往下乘的数
    继续条件是:n*func(n-1,–m)

代码

#include <stdio.h>int func(int n,int m)
{if(m == 0)return 1;else if(m>n)return 0;// m = 3 n = 2 2*1*0else if(n>0)return n*func(n-1,--m);else return 0;
}
int main() 
{int m = 0;int n = 0;scanf("%d %d",&n,&m);// 输入的顺序也不能弄反int ret = func(n,m);printf("%d",ret);return 0;
}

逆序输出

题目

描述
牛牛在尝试把一个整数逆序地输出。

输入描述:
输入一个正整数 n。保证个位数不是 0
输出描述:
逆序输出这个正整数。

示例1
输入:
2345

输出:
5432

思路

结束条件就是 n == 0的时候,因为它的个位数不是0嘛
继续的条件是:func(n/10)
而且要先打印,得到的最后一位数
先打印掉个位数,个位数再除10变成0结束

代码

#include <stdio.h>
#include<stdlib.h>void func(int n)
{if(n == 0)return;//结束时必须返回,不然不会结束,而且不能去打印elseprintf("%d",n%10);func(n/10);
}
int main() 
{int n = 0;scanf("%d",&n);    func(n);return 0;
}

结语

递归最重要的就是去思考它的结束条件
如果有不足之处,还望博友们指出
最后祝福我们题题AC

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/829479.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

挑战特斯拉?深蓝汽车与华为强强联手

作为中国乃至全球汽车行业的盛宴&#xff0c;4月25日在中国国家展览中心揭幕的2024北京国际车展&#xff0c;吸引了无数企业行业人士的关注。 而就在车展开幕当天&#xff0c;深蓝汽车发布会就爆出了一个大新闻&#xff1a;深蓝汽车将携手华为&#xff0c;打造比特斯拉更好的智…

【开发问题记录】启动某个服务时请求失败(docker-componse创建容器时IP参数不正确)

问题记录 一、问题描述1.1 产生原因1.2 产生问题 二、问题解决2.1 找到自己的docker-compose.yml文件2.2 重新编辑docker-compose.yml文件2.3 通过docker-componse重新运行docker-compose.yml文件2.4 重新启动docker容器2.5 查看seata信息 一、问题描述 1.1 产生原因 因为我是…

FPGA 以太网通信UDP通信环回

1 实验任务 上位机通过网口调试助手发送数据给 FPGA &#xff0c; FPGA 通过 PL 端以太网接口接收数据并将接收到的数据发送给上位机&#xff0c;完成以太网 UDP 数据的环回。 2 系统设计 系统时钟经过PLL时钟模块后&#xff0c;生成了两种不同频率和相位的时钟信号&#…

Python 面向对象——6.封装

本章学习链接如下&#xff1a; Python 面向对象——1.基本概念 Python 面向对象——2.类与对象实例属性补充解释&#xff0c;self的作用等 Python 面向对象——3.实例方法&#xff0c;类方法与静态方法 Python 面向对象——4.继承 Python 面向对象——5.多态 1. 封装的基…

unity cinemachine相机 (案例 跟随角色移动)

安装相机包 打开包管理工具 在 unity registry 搜索cinemachine 会在maincamera中生成一个组件cinemachineBrain 只能通过虚拟相机操控 主相机 虚拟相机的参数 案例 1.固定相机效果 位置 在固定的地方 默认的模式 2.相机跟随人物效果 焦距设置 20 跟随设置 把playere…

使用Tortoise 创建远程分支

1。首先创建本地分支branch1&#xff0c;右键tortoise git->创建分支&#xff0c;输入分支名称branch1&#xff0c;确定。 2。右键tortoise git->推送&#xff0c;按下图设置&#xff0c;确定&#xff0c;git会判断远程有没有分支branch1&#xff0c;如果没有会自动创建…

重看Spring聚焦Environment分析

目录 一、理解Environment的设计 &#xff08;一&#xff09;整体理解 &#xff08;二&#xff09;聚焦Profiles分析 &#xff08;三&#xff09;聚焦Properties分析 二、Environment类图结构分析 三、PropertyResolver源码分析 &#xff08;一&#xff09;源码展示说明…

C语言学习/复习36

一、程序的环境与预处理 二、翻译环境与执行环境 三、运行环境 四、预编译(预处理)详解

mac电脑搭建vue环境(上篇)

第一步&#xff1a;mac电脑要有homebrew&#xff0c;如何安装homebrew 点击下方 MAC安装homebrew-CSDN博客 第二步&#xff1a;homebrew安装node.js 第三步&#xff1a;安装npm 第四步&#xff1a;安装webpack 第五步&#xff1a;安装vue脚手架 第六步&#xff1a;可以在…

NumPy 1.26 中文官方指南(一)

NumPy 用户指南 原文&#xff1a;numpy.org/doc/1.26/user/index.html 本指南是一个概述&#xff0c;解释了重要特性&#xff1b;细节请参阅 NumPy 参考文档。 入门指南 什么是 NumPy? 安装 NumPy 快速入门 NumPy&#xff1a;初学者的绝对基础 基础知识和用法 NumPy 基础…

工信部绿色工厂、绿色设计产品、绿色供应链企业、绿色园区名单数据集(2017-2022年)

01、数据简介 工信部致力于推动制造业的绿色转型&#xff0c;为了表彰在绿色制造领域取得显著成绩的企业和园区&#xff0c;工信部发布了绿色工厂公示名单、绿色设计产品公示名单、绿色供应链企业公示名单和绿色园区公示名单。 这些企业和园区在绿色制造方面做出了卓越的贡献…

MySQL__锁

文章目录 &#x1f60a; 作者&#xff1a;Lion J &#x1f496; 主页&#xff1a; https://blog.csdn.net/weixin_69252724 &#x1f389; 主题&#xff1a; MySQL__锁&#xff09; ⏱️ 创作时间&#xff1a;2024年04月27日 ———————————————— 这里写目录…

刷题训练之前缀和

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;熟练掌握前缀和算法。 > 毒鸡汤&#xff1a;学习&#xff0c;学习&#xff0c;再学习 ! 学&#xff0c;然后知不足。 > 专栏选自&#xff1a;刷题…

【Hadoop】-HDFS的存储原理[4]

目录 前言 一、fsck命令 1、HDFS副本块数量的配置 2、fsck命令查看文件的副本数 3、block配置 二、NameNode元数据 1、edits文件 2、fsigame文件 3、NameNode元数据管理维护 4、元数据合并控制参数 5、SecondaryNameNode的作用 三、HDFS数据的读写流程 1、数据写入…

Pytorch 之torch.nn初探 卷积--Convolution Layers

任务描述 本关任务&#xff1a; 本关提供了一个Variable 类型的变量input&#xff0c;按照要求创建一 Conv1d变量conv&#xff0c;对input应用卷积操作并赋值给变量 output&#xff0c;并输出output 的大小。 相关知识 卷积的本质就是用卷积核的参数来提取原始数据的特征&a…

前端HTML5学习1(新增布局,状态,列表,文本,表单控件标签)

前端HTML5学习1&#xff08;新增布局&#xff0c;状态&#xff0c;列表&#xff0c;文本&#xff0c;表单控件标签&#xff09; 新增布局标签新增状态标签新增列表标签新增文本标签新增表单控件属性input新增属性值 新增布局标签 HTML5 引入了许多新的语义化标签&#xff0c;用…

【MySQL】A01、性能优化-参数监控分析

1、参数监控 1.1、MySQL command 查看 mysql>SHOW STATUS; &#xff08;服务器状态变量&#xff0c;运行服务器的统计和状态指标&#xff09; mysql> SHOW VARIABLES;&#xff08;服务器系统变量&#xff0c;实际上使用的变量的值&#xff09; mysql> SHOW STATUS …

SpringBoot---------Hutool

第一步&#xff1a;引入依赖 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-parent</artifactId><version>5.7.17</version></dependency> 第二步&#xff1a;各种用法 ①生成随机数 //生成验证码 String s …

Linux磁盘管理与文件系统

目录 一.磁盘基础 磁盘结构 二.MBR 磁盘分区结构 三.文件系统类型 XFS文件系统 SWAP&#xff0c;交换文件系统 四.磁盘分区 linux系统添加并使用新硬盘的步骤 五 .创建文件系统 mkfs mkfs命令 挂载、卸载文件系统 挂载文件系统、ISO镜像到指定文件夹 ​编辑umount…