数据结构--第七天

递归

-递归的概念

递归其实就是一种解决问题的办法,在C语言中:递归就是函数自己调用自己

-递归的思想

递归的思考方式就是把大事化小的过程

递归的 就是递推 的意思, 就是回归的意思

递归是少量的代码完成大量的运算

-递归的限制条件

1.递归存在限制条件当满足这个限制条件,便不再继续

2.每次递归调用之后越来越接近这个限制条件

-示例代码

复制代码
#include <stdio.h>

//求和
int sum(int n){
    //递归终止条件
	if(n==1){
		return 1;	
	}
	return sum(n-1)+n; 
}

//求菲波纳妾数列
int fib(int n){
    //递归终止条件
	if(n==1 || n==2){
		return 1;
	}
	return fib(n-1)+fib(n-2);
}

//猴子吃桃
int monkey(int n){
    //递归终止条件
	if(n==1){
		return 1;	
	}
	return 2*(monkey(n-1)+1);
}

int main(){
	int res_1=sum(100);
	printf("res=%d",res_1);
	int res_2=fib(6);
	printf("res=%d",res_2);
	int res_3=monkey(4);
	printf("res=%d",res_3);
	return 0;
}

-输出结果

相关推荐
CoderYanger15 小时前
A.每日一题——3432. 统计元素和差值为偶数的分区方案
java·数据结构·算法·leetcode·1024程序员节
博语小屋15 小时前
线程同步与条件变量
linux·jvm·数据结构·c++
Ayanami_Reii15 小时前
进阶数据结构-AC自动机
数据结构·算法·动态规划·字符串·ac自动机
带鱼吃猫15 小时前
数据结构:顺序表与基于动态顺序表的通讯录项目
数据结构·链表
报错小能手15 小时前
数据结构 AVL二叉平衡树
数据结构·算法
liu****16 小时前
20.预处理详解
c语言·开发语言·数据结构·c++·算法
代码游侠16 小时前
数据结构——哈希表
数据结构·笔记·学习·算法·哈希算法·散列表
小龙报17 小时前
【算法通关指南:数据结构与算法篇】树形结构遍历指南:DFS 递归深搜与 BFS 队列广搜实战解析
c语言·数据结构·c++·算法·链表·深度优先·visual studio
Aurorar0rua17 小时前
C Primer Plus 14.17 复习题
c语言·开发语言·数据结构
吃着火锅x唱着歌17 小时前
LeetCode 2909.元素和最小的山形三元组II
数据结构·算法·leetcode