算法设计与分析期末考试复习(一)

news2025/7/14 6:03:01

递归

程序调用自身的编程技巧称为递归。
在调用函数时系统需要完成3件事:

  1. 将所有实参(指针),返回地址传递给被调用的函数
  2. 为被调用函数的局部变量分配存储区
  3. 将控制转移到被调用函数的入口

从被调用函数返回时系统也要做3件事:

  1. 保存被调用算法的计算结果(返回值)
  2. 释放分配给被调用算法的存储空间
  3. 依照被调算法保存的返回地址将控制转移回到调用算法

递归过程执行时需多次调用自身。多个(相同)函数嵌套调用,信息传递和控制转移通过栈实现

  1. 每一次递归调用时,需要为过程中所使用的参数、局部变量等另外分配存储空间
  2. 层层向下递归,退出时次序正好相反
  3. 每层递归调用需分配的空间形成递归工作记录,用栈按照后进先出规则管理这些信息

如果函数调用它本身,那么此函数就是递归的,例如求n!

int factoria(int n){
	if(n<=1){
		return 1;
	}else{
		return n*factoria(n-1);
	}
}

在这里插入图片描述
遇到如下三种情况,可以考虑使用递归

  1. 问题定义是递归的
  2. 解决问题时采用的数据结构是递归定义的
  3. 问题的求解过程是递归的

问题定义是递归的

递归法求幂

int power(int x, int n)
	{
	  if ( n == 0 )
	    return 1;
	  else
	    return x * power(x,n-1);
	}

可简化为:

int power(int x,int n){
	return 0 ? 1 : x*power(x,n-1)
}

斐波那契数列(黄金分割数列):假设一对初生兔子一个月才到成熟期,而一对成熟兔子每月会生一对兔子,那么由一对初生的兔子开始,n个月后会有几对兔子?1、1、2、3、5、8、13、21、…这个数列从第三项开始,每一项都等于前面两项之和。
在这里插入图片描述
递归求解斐波那契数列,重复求解子问题,算法复杂度O(2n)

long fib1(int n){
	if(n <= 1){
		return 1;
	}
	else{
		return fib(n-1)+fib(n-2);
	}
}

递推求解斐波那契数列数列,而F(n) = F(n-1) + F(n-2); (n>=2),F(n)具有无后效性,只需记住前两个状态的结果即可,算法复杂度O(n)。

long fib2(int n){
	long f1 = 1,f2 = 1,fu;
	for(int i=2; i<=n;i++){
		fu = f1 + f2;
		f1 = f2;
		f2 = fu;
	}
	return fu;
}

问题采用的数据结构是递归的

二叉树链式存储结构:二叉链表。

typedef struct node{
	Entrytype data;
	struct node *lchild,*rchild;
}BTNode,*BTPtr;

在n个结点的二叉链表中,共有2n个指针,所有有n-1个指针指向结点,所有有n+1个空指针域。

中序遍历递归算法

void inOrder(BTPtr bt){
	if(bt != NULL){
		inorder(bt->lchild);
		printf("%c\t",bt->data);
		inorder(bt->rchild);
	}
	return;;
}

后序遍历

void postOrder(BTPtr bt){
	if(bt != NULL){
		postOrder(bt->lchild);
		postOrder(bt->rchild);
		printf("%c\t",bt->data);
	}
	return;
}

问题的求解过程是递归的

汉诺塔问题:有A、B、C3个塔座,在塔座A上有一叠共n个圆盘,自上而下由小到大叠在一起,编号为1,2,…,n,:要求将塔座A上的圆盘全部移到塔座C上,仍按同样顺序叠置。在移动圆盘时遵守以下规则:每次只允许移动1个圆盘,任何时刻都不允许将较大的圆盘压在较小的圆盘之上
将3个盘子从A移到C,以B为辅助,共7步(2n-1次)完成。
用递归技术求解汉诺塔问题:

  1. 当n=1时,问题可以直接求解,一步完成。
  2. 当n>1时,分三步完成:将n-1个较小盘子设法移动到辅助塔座(构造出一个比原问题规模小1的问题),将最大的盘子从原塔座移至到目标塔座,将n-1个较小的盘子设法从辅助塔座移至到目标塔座。
void hanoi(int n,int src,int tar,int aux){
	if(n > 0){
		hanoi(n-1,src,aux,tar);//将n-1个盘子从原塔座移到辅助塔座上。
		move(src,tar);//将源塔座上最后的1个盘子移到目标塔座上。
		hanoi(n-1,aux,tar,src);//将辅助塔座上n-1个盘子移到目标塔座上。
	}
}

排列问题:生成n个元素的全排列

void swap(int &a,int &b){
	int temp = a;
	a = b;
	b = temp;
}

void Perm(int list[],int k,int m){
	//当只剩下一个元素时
	if(k == m){
		for(int i=1;i<=m;i++){
			printf("%d\t",list[i]);
		}
	}else{
		for(int i=k;i<=m;i++){
			swap(list[k],list[i]);
			Perm(list,k+1,m);
			swap(list[k],list[i]);
		}
	}
}

整数划分问题:将正整数n表示成一系列正整数之和:n=n1+n2+…+nk,其中n1>=n2>=…nk
q(n,m):最大加数n1不大于m的划分个数记作q(n,m),

  1. q(n,n) = 1+q(n,n-1):正整数n的划分由n1=n和n1<=n-1的划分组成。
  2. q(n,m) = q(n,m-1) + q(n-m,m)

在这里插入图片描述

int q(int n,int m){
	if(n < 1 || m < 1){
		return 0;
	}else if(n == 1 || m == 1){
		return 1;
	}else if(n == m){
		return q(n,n-1) + 1;
	}else{
		return q(n,m-1) + q(n-m,m);
	}
}

递归算法:直接或间接地调用自身的算法。
递归函数:用函数自身给出定义的函数。
边界条件和递归方程是递归的两个基本要素。

递归小结

递归算法的优点:结构清晰,易于理解,而且容易用数学归纳法来证明算法的正确性,因此用递归技术来设计算法很方便。
递归算法的缺点:在执行时要多次调用自身,运行效率低,无论是计算时间还是占用存储空间都要比非递归算法要多。一些运算步骤可能重复运行,会进一步降低效率。

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

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

相关文章

最近一直在做优化

大家好啊&#xff0c;好久没写文章了&#xff0c;最近收到了一些朋友的微信&#xff0c;问还写不写文章。 当然会继续写&#xff0c;只不过最近工作和生活忙的焦头烂额&#xff0c;一直没抽出时间来好好整理下自己&#xff0c;重整旗鼓继续写文。 总的来说&#xff0c;被两件…

C语言的学习小结——数组

一、一维数组的创建与初始化 1、格式&#xff1a; type_t arr_name[const_n];//type_t 是指数组的元素类型 //const_n 是一个常量表达式&#xff0c;用来指定数组的大小 注&#xff1a; 数组是使用下标来访问的&#xff0c;下标从0开始。 数组的大小可以通过计算得到&…

问卷调查设计-SurveyJS的使用(定制)

前言 距离上一次记录SurveyJS的文章已经过去大半个月了&#xff0c;也该完结一下子了&#xff0c;正好项目结束&#xff0c;抽出时间记录一下使用SurveyJS过程中的做的一些自定义配置需要哪些方法及属性&#xff08;这里根据个人项目需要做的一些方法总结&#xff0c;不包含全…

【2023】华为OD机试真题Java-题目0221-AI处理器组合

AI处理器组合 题目描述 某公司研发了一款高性能AI处理器。每台物理设备具备8颗AI处理器,编号分别为0、1、2、3、4、5、6、7。编号0-3的处理器处于同一个链路中,编号4-7的处理器处于另外一个链路中,不通链路中的处理器不能通信,如下图所示。现给定服务器可用的处理器编号数…

这才叫装机必备,这3款高质量电脑软件,内存满了也绝不卸载

闲话少说&#xff0c;直上狠货。 1、quicker quicker是一款指尖电脑工具&#xff0c;使用它实现常用操作&#xff0c;就在手边&#xff0c;点击鼠标中键&#xff0c;即可弹出&#xff0c;位置跟随鼠标&#xff0c;面板窗口的下半部分&#xff0c;它会随当前操作的软件自动加载设…

【Yolov5】保姆级别源码讲解之-推理部分detect.py文件

推理部分之detect.py文件讲解1.下载Yolov5的源码2. 主函数讲解3.文件标头的注释4. main函数的5. run函数5.1 第一块参数部分5.2第二块&#xff0c;传入数据预处理5.3 第三块创建文件夹5.4 第四块 加载模型的权重5.5 第五块 Dataloader 加载模块5.6 第六块 推理部分 Run inferen…

python 魔法方法之 __ slots __

python 魔法方法之 __ slots __ __ slots __ __slots__是python class的一个特殊attribute&#xff0c;能够节省内存空间。正常情况下&#xff0c;一个类的属性是以字典的形式来管理, 每个类都会有__ dict__ 方法。但是我们可以通过 设置 __ slots__ 来将类的属性构造成一个静…

input 子系统

简介 先来了解什么是输入设备&#xff1f; 常见的输入设备有键盘、 鼠标、 遥控杆、 书写板、 触摸屏等等,用户通过这些输入设备与 Linux 系统进行数据交换。 什么是输入系统&#xff1f; 输入设备种类繁多&#xff0c; 能否统一它们的接口&#xff1f; 既在驱动层面统一&…

springboot+vue邯郸地标美食导游平台

设计者应有软件程序开发方面的专业理论基础知识&#xff0c;有一定的分析和解决问题的能力&#xff0c;有一定的收集、整理、信息检索等方面的能力&#xff0c;善于综合、勤于思考&#xff0c;具有一丝不苟&#xff0c;精益求精&#xff0c;刻苦钻研的工作精神&#xff0c;勇于…

基于遗传算法的柔性生产调度研究(Matlab代码实现)

&#x1f468;‍&#x1f393;个人主页&#xff1a;研学社的博客&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5;&#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密…

S-Paper电子纸在生产车间中的应用

S-Paper电子纸在生产车间中的应用应用背景在传统的制造企业的生产流程中&#xff0c;生产线上的工件信息&#xff0c;加工信息等等在生产前都需要生产车间打印出来&#xff0c;然后再分发至生产线上对应的工件工位&#xff0c;纸张都是使用完后都是作废销毁&#xff0c;这样下来…

SQL零基础入门学习(九)

SQL零基础入门学习&#xff08;八&#xff09; SQL UNION 操作符 UNION 操作符用于合并两个或多个 SELECT 语句的结果集。 请注意&#xff0c;UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时&#xff0c;每个 SELECT 语句中的列的顺序…

Xmake v2.7.7 发布,支持 Haiku 平台,改进 API 检测和 C++ Modules 支持

layout: post.cn title: “Xmake v2.7.7 发布&#xff0c;支持 Haiku 平台&#xff0c;改进 API 检测和 C Modules 支持” tags: xmake lua C/C package modules haiku cmodules categories: xmake Xmake 是一个基于 Lua 的轻量级跨平台构建工具。 它非常的轻量&#xff0c;没…

Android仿京东金融的数值滚动尺功能

自定义数值滚动尺,这个用的还是挺多的&#xff0c;例如京东金融的通过滚动尺选择金额等,而这次就是高仿京东金融的数值滚动尺。首先看看下效果图&#xff0c;如下&#xff1a;首先先给你们各个变量的含义&#xff0c;以免在后面的讲解中不知变量的意思&#xff0c;代码如下://最…

高/低压供配电系统设计——安科瑞变电站电力监控系统的应用

摘 要&#xff1a;在电力系统的运行过程中&#xff0c;变电站作为整个电力系统的核心&#xff0c;在保证电力系统可靠的运行方面起着至关重要的作用&#xff0c;基于此需对变电站监控系统的特点进行分析&#xff0c;结合变电站监控系统的功能需求&#xff0c;对变电站电力监控系…

载誉而归!昂视荣膺CAIMRS 2023「自动化创新奖」

2月24日&#xff0c;由中国工控网举办的第二十一届自动化及数字化年会在苏州希尔顿酒店隆重举行&#xff0c;昂视受邀参加本次活动。会上&#xff0c;中国工控网发布了第二十一届自动化及数字化年度自动化创新奖&#xff0c;昂视凭借LP8000系列超高精度3D激光轮廓仪斩获“自动化…

浅谈`AI`的那些事-环境搭建

人工智能(AI)-环境搭建 目录导航人工智能(AI)-环境搭建1. 为什么人工智能(AI)首选Python&#xff1f;2. python在AI上的优势2.1 python在AI上的优势2.1.1 语法简单&#xff0c;编码少。2.1.2 内置了几乎所有的AI项目库2.1.3 开源和可用于广泛编程2.2 python的特点3. PyTorch环境…

JVM详解——垃圾回收

如果有兴趣了解更多相关内容的话&#xff0c;可以看看我的个人网站&#xff1a;耶瞳空间 GC&#xff1a;垃圾收集(Gabage Collection)&#xff0c;内存处理是编程人员容易出现问题的地方&#xff0c;忘记或者错误的内存。不当的回收可能会导致程序或系统的不稳定甚至崩溃&…

PHP面向对象05:MVC和smarty

PHP面向对象05&#xff1a;MVC 和 smarty一、MVC思想二、MVC代码设计三、项目单一入口四、Smarty模板技术1. 模板技术原理2. Smarty简单使用3. Smarty配置五、Smarty模板变量六、Smarty内置函数七、Smarty外部函数一、MVC思想 MVC思想&#xff0c;是一种基于面向对象思想形成的…

如何将本地文件自动备份到百度网盘?

如何将本地文件自动备份到百度网盘&#xff1f;说到网盘的使用&#xff0c;大家第一个想到的肯定是百度网盘&#xff0c;百度网盘第一个提出网盘这个概念&#xff0c;相信很多小伙伴都是百度网盘的忠实用户&#xff0c;大家也非常喜欢使用百度网盘来存储文件。为什么百度网盘深…