算法案例之递归

直接或间接调用自身的算法过程

  • 设计思路:遵循基准情形和递归情形两大原则,将问题分解为同类型子问题求解;底层基于栈结构,调用时压入当前状态,求解后依次出栈。
  • 适用场合:适用于可按分治思想拆解为同类子问题的场景。
  • 注意事项:必须设置终结条件防止无限递归,控制递归深度避免栈溢出

【例题1】斐波那契数列

斐波那契数列定义:

Fib(n)=1 n=1

Fib(n)=1 n=2

Fib(n)=Fib(n-1)+Fib(n-2) n>2

cpp 复制代码
#include<iostream>
using namespace std;
int Fib(int n){
    if(n==1 || n==2)
    	return 1;
    else
    	return Fib(n-1)+Fib(n-2);
}
int main(){
    int n=10;
    cout<<Fib(n)<<endl;
    return 0;
}

【例题2】选择排序

将数组{1,2,3,6,8,4,10,7,5,9}按照从小到大的顺序进行排序

cpp 复制代码
#include<iostream>
using namespace std;
void swap(int &a,int &b){		//标准的交换函数
    int temp = a;
    a = b;
    b = temp;
}
int findmin(int a[],int i,int n){
	int minindex=i;		// 记录最小值的索引
	for(int j=i+1;j<n;j++){
		if(a[minindex] > a[j]){		// 找到更小的值
			minindex=j;		// 更新最小值索引
		}
	}
	return minindex;		// 返回最小值的索引
}
void sort(int a[],int n,int i){
	if(i>=n-1) return;  //递归出口
	  int minindex = findmin(a,i,n);	// 在[i..n-1]中找最小值
	  if(minindex!=i) swap(a[i],a[minindex]);	// 交换到位置i
	  sort(a,n,i+1); // 递归排序剩余部分
}
int main(){
	int a[]={1,2,3,6,8,4,10,7,5,9};
	int n=sizeof(a)/sizeof(a[0]);
	sort(a,n,0);
	for(int i=0;i<n;i++){
		cout<<a[i];
	} 
	return 0;
}

【例题3】冒泡排序

将数组{1,2,3,6,8,4,10,7,5,9}按照从小到大的顺序进行排序

cpp 复制代码
#include<iostream>
using namespace std;
void swap(int &a,int &b){		//标准的交换函数
    int temp = a;
    a = b;
    b = temp;
}
void sort(int a[],int i,int n){
	if(i>=n) return;		// 递归出口
	for(int j=n;j>i;j--){	// 内层循环:从后向前冒泡
		if(a[j]<a[j-1]) swap(a[j],a[j-1]); 
	}
	sort(a,i+1,n);		// 递归调用,处理下一个位置
}
int main(){
	int a[]={1,2,3,6,8,4,10,7,5,9};
	int n=sizeof(a)/sizeof(a[0]);
	sort(a,0,n-1);
	for(int i=0;i<n;i++){
		cout<<a[i];
	}
	return 0;
}

【例题4】插入排序

将数组{2,5,8,3,6,1,4,7}按照从小到大的顺序进行排序

cpp 复制代码
#include<iostream>
using namespace std;
int find(int a[],int i){
	for(int j;j<=i;j++){
		if(a[j]>=a[i]) return j;
	}
	return i;
}
void move(int a[],int index,int i){
	for(int k=i;k>=index;k--){
		a[k+1]=a[k];
	}
}
void sort(int a[],int i,int e){
	//递归出口
	if (i>e) return;
	//递归体
	//大问题变成小问题
	int index=find(a,i);
	int temp=a[i];
	move(a,index,i-1);
	a[index]=temp;
	//小问题求解
	sort(a,i+1,e);
}
int main(){
	int a[]={2,5,8,3,6,1,4,7}; 
	//数组长度 
	int n=sizeof(a)/sizeof(a[0]);
	sort(a,0,n-1);
	//输出数组的值
	for(int i = 0; i < n; i++) {
		cout << a[i];
	}
	return 0;
} 
相关推荐
Wect17 分钟前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP12 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
端平入洛19 小时前
delete又未完全delete
c++
颜酱20 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试