概述
解读递归算法! |
- 本文章属于 数据结构与算法 专栏系列,欢迎关注,链接: 数据结构与算法。文章会持续更新,希望大家多点赞收藏加转发!
- 专栏 文章总目录 链接:数据结构与算法!
文章目录
- 一. 什么是递归
- 1.1. 递归的定义
- 1.2. 何时使用递归
- 1.3. 递归模型
- 二. 递归算法的设计
- 2.1. 递归算法设计的步骤
- 2.2. 基于递归数据结构的递归算法设计
- 2.3. 基于递归求解方法的递归算法设计
- 三. 递归总结
- 3.1. 递归技术总结
- 3.2. 递归算法设计总结
- 3.3. 递归函数设计中几个问题
一. 什么是递归
1.1. 递归的定义
- 递归的定义:
data:image/s3,"s3://crabby-images/ccf44/ccf44b246a710656cc5e2511011f86f95e786b73" alt=""
- 尾递归:
data:image/s3,"s3://crabby-images/68b89/68b894d119651fc2e8fcdc06387d4c1ad6a30d7c" alt=""
data:image/s3,"s3://crabby-images/37000/370003d1d951bf713ee928fcb2cd72b8b4930173" alt=""
1.2. 何时使用递归
- 在以下三种情况,常常要用到递归的方法:
data:image/s3,"s3://crabby-images/13a6b/13a6b29d77dcc190b7b8b3d8d666c1cb1c6034ee" alt=""
data:image/s3,"s3://crabby-images/c0cc0/c0cc038b2ca9b4aadf1da7ca9529cd2e034ff8c7" alt=""
1.3. 递归模型
data:image/s3,"s3://crabby-images/46042/46042190260df9a32423b34ec8722cebb36c1481" alt=""
data:image/s3,"s3://crabby-images/d8be4/d8be4d2291b7fa9f26b3b1470cba3939323b2e02" alt=""
- 下面的例子: 统计全国GDP这个大问题转化为北京市,上海市。然后又继续划分,直到某个企业。
data:image/s3,"s3://crabby-images/6c954/6c954a98bb9f5aefe36209555a95fe86f7c4d1f3" alt=""
data:image/s3,"s3://crabby-images/acf68/acf68b9bfe5934ac2e32ea27dd8b70c16ec4569d" alt=""
- 斐波那契数列:
data:image/s3,"s3://crabby-images/94dda/94dda6c01e33469664f72e5ad3e9c882a1bf3e74" alt=""
#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 = 6;
cout << fib(n) << endl;
system("pause");
return 0;
}
- 输出结果:
8
请按任意键继续. . .
二. 递归算法的设计
2.1. 递归算法设计的步骤
data:image/s3,"s3://crabby-images/d977d/d977d996c6ab29705bf454030a2346d23079949b" alt=""
- 下面的例子:
data:image/s3,"s3://crabby-images/f248a/f248ac210c57ef368d21369ba9b331bc91de9082" alt=""
#include <iostream>
#include <vector>
using namespace std;
float f(vector<float> &arr, int i)
{
float m;
if (i == 0)
return arr[0];
else
{
m = f(arr, i - 1);
return m > arr[i] ? arr[i] : m;
// if (m > arr[i])
// return arr[i];
// else
// return m;
}
}
int main()
{
vector<float> arr = {1, 2.2, 3, 5, 8, 9, 10, 3.3, 0.5};
cout << f(arr, arr.size() - 1) << endl;
system("pause");
return 0;
}
- 输出结果:
0.5
请按任意键继续. . .
2.2. 基于递归数据结构的递归算法设计
data:image/s3,"s3://crabby-images/fac27/fac27140d0071bd3b0b64bf47272d7b51ef39f9c" alt=""
- 下面的例子:
data:image/s3,"s3://crabby-images/459be/459be88c1a2edb8944ef9bd11ad2042a4135bcb1" alt=""
#include <iostream>
using namespace std;
typedef int ElemType; //简单的数据元素类型
typedef struct LNode //单链表结点类型
{
ElemType data; //数据域
LNode *next; //指针域:指向直接后继结点
} LNode, *LinkList;
// =============================给数据域赋值====================================
void input(ElemType *ep) //实现数据域元素输入的定制函数
{
cout << "input the data of linklist: ";
cin >> *ep; //在函数中可以写更加复杂、任意形式、任意数目的输入
}
// =============================1. 头插法创建单链表=============================
// LinkList *L:相当于LNode **L是一个指针,L存放的类型是LinkList(指针类型),就只指针的指针。
void createLinkF(LinkList *L, int n, void (*input)(ElemType *))
{ //头插法创建单链表,调用input输入函数输入数据
LinkList s;
*L = new LNode; //创建头结点,把这个节点的地址赋值给指针*L
(*L)->next = NULL; //初始时为空表
for (; n > 0; n--) //创建n个结点链表
{
s = new LNode; //创建新结点
input(&s->data); //调用input输入数据域
s->next = (*L)->next; //将s增加到开始结点之前
(*L)->next = s;
}
}
// ==================================2. 打印链表=================================
void printLinkList(LinkList s)
{
while (s != NULL)
{
cout << s->data << " ";
s = s->next;
}
}
// +++++++++++++++++++++++++++++ 求单链表中数据节点 +++++++++++++++++++++++++++++++
int count(LinkList s)
{
if (s == NULL)
return 0;
else
return count(s->next) + 1;
}
// ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
int main()
{
LinkList L;
int n;
cout << "input the length of linklist: ";
cin >> n;
//L本身已经是一个指针,&L指针变量的地址作为实参传递;那么用来接收的应该是一个指针的指针。
createLinkF(&L, n, input);
printLinkList(L->next); //去掉头结点;
cout << "nthe length of linklist(count): ";
cout << count(L->next) << endl;
system("pause");
return 0;
}
input the length of linklist: 5
input the data of linklist: 22
input the data of linklist: 33
input the data of linklist: 44
input the data of linklist: 12
input the data of linklist: 24
24 12 44 33 22
the length of linklist(count): 5
请按任意键继续. . .
data:image/s3,"s3://crabby-images/07e3a/07e3a74132a3b62a2aa6f4aaeea88714d0c99fe2" alt=""
#include <iostream>
using namespace std;
typedef int ElemType; //简单的数据元素类型
typedef struct LNode //单链表结点类型
{
ElemType data; //数据域
LNode *next; //指针域:指向直接后继结点
} LNode, *LinkList;
// =============================给数据域赋值====================================
void input(ElemType *ep) //实现数据域元素输入的定制函数
{
cout << "input the data of linklist: ";
cin >> *ep; //在函数中可以写更加复杂、任意形式、任意数目的输入
}
// =============================1. 头插法创建单链表=============================
// LinkList *L:相当于LNode **L是一个指针,L存放的类型是LinkList(指针类型),就只指针的指针。
void createLinkF(LinkList *L, int n, void (*input)(ElemType *))
{ //头插法创建单链表,调用input输入函数输入数据
LinkList s;
*L = new LNode; //创建头结点,把这个节点的地址赋值给指针*L
(*L)->next = NULL; //初始时为空表
for (; n > 0; n--) //创建n个结点链表
{
s = new LNode; //创建新结点
input(&s->data); //调用input输入数据域
s->next = (*L)->next; //将s增加到开始结点之前
(*L)->next = s;
}
}
// +++++++++++++++++++++++++++++ 正向显示单链表中的值 +++++++++++++++++++++++++++++
void traverse(LinkList s)
{
if (s == NULL)
return;
cout << s->data << " ";
traverse(s->next);
}
// +++++++++++++++++++++++++++++ 反向显示单链表中的值 +++++++++++++++++++++++++++++
void traverse_R(LinkList s)
{
if (s == NULL)
return;
traverse_R(s->next);
cout << s->data << " ";
}
int main()
{
LinkList L;
int n;
cout << "input the length of linklist: ";
cin >> n;
//L本身已经是一个指针,&L指针变量的地址作为实参传递;那么用来接收的应该是一个指针的指针。
createLinkF(&L, n, input);
cout << "traverse:";
traverse(L->next); //去掉头结点;
cout << "ntraverse_R:";
traverse_R(L->next);
system("pause");
return 0;
}
input the length of linklist: 4
input the data of linklist: 1
input the data of linklist: 2
input the data of linklist: 3
input the data of linklist: 4
traverse:4 3 2 1
traverse_R:1 2 3 4
请按任意键继续. . .
2.3. 基于递归求解方法的递归算法设计
data:image/s3,"s3://crabby-images/69cfb/69cfb356d7602944d0a44f5c8a3da268c21c78f4" alt=""
- 下面的例子:
三. 递归总结
3.1. 递归技术总结
data:image/s3,"s3://crabby-images/2bae9/2bae91e0100e769b2c2cd37b72768917d20548bf" alt=""
3.2. 递归算法设计总结
data:image/s3,"s3://crabby-images/8cc7d/8cc7d225e69172bfbb00f385c8fdee7152c93d1c" alt=""
3.3. 递归函数设计中几个问题
data:image/s3,"s3://crabby-images/add22/add22016f04bbffd1d620effc0a386e78028e6db" alt=""
data:image/s3,"s3://crabby-images/7134a/7134ac938beaa58fba3346772b4678a0588c79f7" alt=""
最后
以上就是坚定小土豆为你收集整理的『数据结构与算法』解读递归算法!一. 什么是递归二. 递归算法的设计三. 递归总结的全部内容,希望文章能够帮你解决『数据结构与算法』解读递归算法!一. 什么是递归二. 递归算法的设计三. 递归总结所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复