【算法】学习笔记(2):递归思想

0 回顾

之前的笔记(0)和笔记(1),我们介绍了算法的基本含义,并且举了一些实例,同时理解了,算法就是人类在教计算机做事情!

我们知道,算法就是解决问题的方案,我们将自然语言描述的问题,转换为符号语言,再解决问题,使用计算机思维,构建解决问题的算法,最后转换为计算机可以识别的语言,教会计算机,让它帮助我们解决问题。

在算法设计的时候,我们需要关注其时间和空间的复杂度,这与实际问题有关,可能关注事件,也可能关注空间,也可能二者兼有。

下面,我们来看看递归思想,并且使用实例来理解抽象的思想。

1 递归思想

递归是可能计算机与人类最大的不同,人类是递推思维,能够发散,计算机是递归思维,能够做重复且简单的固定事情。

因此,我们教计算机做事的时候,要尽可能简单且固定,也就是,我们需要将一个复杂的问题,拆解成若干小问题,这些小问题最好还是已知的,已经被解决的,这样,我们就很容易能够设计出一个算法,并且教会计算机做事。

1.1 递归的含义

所谓的递归,看起来就像:同样的一件事情,做了很多遍,虽然每一次的代码一样,但是每一次的数据不一样,导致行为不一样,并且,会有一个尽头,一旦走到尽头了,就得原路返回来。

我们看一个例子
在这里插入图片描述

#include <iostream>
using namespace std;void story(int i) {if (i > 10)return;cout << "从前有个庙,庙里有个老和尚,老和尚给小和尚讲故事" << endl;cout << "讲的故事是什么呢?讲的是:" << endl;story(i + 1);
}int main()
{story(1);return 0;
}

这就是生活中的一个递归的例子,还蛮有趣的!

注意,它并不是循环!与循环还是有差别的,最重要的就是,递归在条件终止之后,会返回来,而循环,条件终止就停了。

1.2 递归算法的重要结构

  1. 终止条件 & 终止处理办法
  2. 递归处理方法

在这里插入图片描述

我们知道,递归不可能无限进行下去,因此需要终止条件,以及触发该条件后对应的处理方案。

并且,更重要的是,我们需要知道递归如何处理

对于递归程序,通常都是解决一个小问题

我们将一个大问题分解成若干个小问题,然后,这些小问题的处理方式是相似的,我们用递归来分别解决每一个小问题,得到每个小问题的解,之后将这些解合并。

阶乘问题

在这里插入图片描述
先列出递归方程,再转换为程序即可。

// 阶乘问题
int factorial(int n) {if (n <= 0)return 1;elsereturn n * factorial(n - 1);
}

如果不用递归呢?

使用递推! 从1到n.用循环搞定。

// 不用recursion的阶乘,递推
int factorial2(int n) {if (n == 0)return 1;int result = 1;for (int i = 1; i <= n; i++) {result *= i;}return result;
}

递归特点:有去有回!从n到1!从结果到起点,再返回来。

对于递归来说,最开始目标的n就是已知的,然后逐渐变化到临界值,经过层层处理,再返回来。关键点:递归方程!

斐波那契数列

递归方程

  1. f(n) = 1,n = 1或n = 0
  2. f(n) = f(n-1) + f(n-2),n > 1
// 斐波那契数列
int fib(int n) {if (n == 1 || n == 0)return 1;return fib(n - 1) + fib(n - 2);
}

在这里插入图片描述
迭代:就是重复执行一些指令,指令是一定的,但是相关的数据是变化的。

递归调用的过程,终点参数在不断变化,一直在逼近终点,最终停下来,依次返回。

小结

我们先将一个问题,使用符号语言描述,拆解问题,将其转换成递归方程,使用数学语言描述,然后将其转换为算法和实际的程序。

所谓的递归,就是先给出终点参数,它是复杂的,然后随着参数的减小,会逐渐简单,然后得到最简单的结果,之后再往回走,就能获得复杂问题的结果。

这与人类思维不一样,人类通常是递推,先解决简单问题,再逐渐复杂化,最终解决复杂问题。

因此,求解问题的时候,可以简单问题找规律,最终获得复杂抽象的方程,从而获得最终结果。

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

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

相关文章

【计算机系统设计】实践笔记(5)插叙:内外有别之CPU和Memory

区分CPU的内外 首先明确&#xff0c;内存&#xff0c;不在CPU内&#xff0c;我们的CPU是会有数据和指令端口的&#xff0c;然后去访问内存和外设。 而CPU设计&#xff0c;我们所说的单周期&#xff0c;多周期和流水线&#xff0c;描述的都是CPU&#xff0c;而不是Memory&…

【计算机系统设计】实践笔记(5)改进数据通路:beq和bne指令分析与实现

接下来的分析和实践非常粗糙&#xff0c;因为跟之前一样的分析流程&#xff0c;不再多说了&#xff0c;如果前面真的掌握&#xff0c;这里不看也罢。 分析 先看beq指令。 ALU输入的是rs和rt&#xff0c;不输入imm&#xff0c;进行subu操作&#xff0c;判断是否为zero&#x…

【算法】学习笔记(4):分治思想 归并排序

分治思想&#xff0c;分治策略&#xff0c;自古有之&#xff0c;与人类生活息息相关&#xff0c;其本质是将大问题拆解为小问题&#xff0c;小问题转换为已知解的问题&#xff0c;进而求解。 军队管理&#xff0c;国家分级治理…… 大规模数据排序&#xff0c;例如10000000000…

【算法】学习笔记(5):快速排序

注意一个C的坑 sizeof()这个函数静态数组可以求长度&#xff0c;动态new出来的数组不行&#xff0c;因为针对的是指针……&#xff0c;不过既然的动态数组了&#xff0c;其长度本身必然是一个变量了&#xff0c;你没有必要这么求长度。 下面看快速排序的代码。 #include <…

【计算机系统设计】实践笔记(6)改进数据通路:lw和sw指令

不想多说了……前面的铺垫足够了&#xff0c;剩下的自己做做应该也会了&#xff0c;如果遇到问题&#xff0c;就搜一下自己查阅就好。 这篇水过&#xff0c;没有太多技术点。 唯一注意的是&#xff0c;引入的RAM和ROM的clk触发问题&#xff0c;可能引起时序问题&#xff0c;等…

html css 核心设计理念

分开看&#xff01; 从不同视角&#xff0c;独立地去看某一部分内容&#xff0c;使用聚焦视角&#xff0c;进行独立操作和批量操作。

html css 学习笔记(1)背景相关

背景颜色 图片 插入图片img背景图片 背景图片 3. logo 4. 大图 5. 装饰性小图 便于控制位置&#xff01; 插入后会执行自动平铺&#xff0c;这与插入图片是不同的&#xff01; div{width: 600px;height: 300px;background-image: url(img/登录用户头像.png); }小结 盒子的第…

html css a标签的应用

作为普通链接转换为行内块元素 转换为行内块元素之后&#xff0c;就可以给其各种块行为&#xff0c;加背景&#xff0c;加背景图片&#xff0c;设置宽高&#xff0c;内外边距…… 块行为可以的&#xff0c;它都行&#xff0c;唯一的区别&#xff0c;它这个盒子是个链接&#…

GitHub回滚

不要直接退回到很久前的历史版本&#xff0c;这很可能引起文件冲突&#xff0c;可以一步步回滚&#xff0c;先回滚最近的&#xff0c;从近到远一步步滚到目标。

2020-12-15 CPU设计复盘

SOC修改 将之前完成的31条指令单周期CPU进行了重构&#xff0c;将其分开&#xff0c;实现了内外有别&#xff0c;将CPU、指令ROM和数据RAM。 这样&#xff0c;以后为其增加接口外设&#xff0c;总线控制&#xff0c;才更加清晰&#xff0c;这是进一步封装和抽象。 MARS大坑 …

Tomcat 学习笔记(0)

JavaWeb 用Java写的程序&#xff0c;可以在浏览器运行。 Request & Responce Web资源 Web服务器 我们在自己的主机启动Tomcat服务器&#xff0c;然后运行它&#xff0c;就能够通过主机访问这个服务器&#xff0c;这个服务器能够运行我们的程序。 部署Web工程 法1 将web…

计算机系统 学习笔记(0)南京大学(一)第一周

课程&#xff1a;计算机系统基础 核心理念&#xff1a;人类世界与计算机世界的异同 人类世界 直观感受数学 计算机世界 与数学不同&#xff0c;存储首先&#xff0c;各层次与现实世界不同 我们关注点是差异点&#xff01; 一样的你就不用关心了&#xff0c;关心差异&#…

x86架构下 CF与OF标志位 带符号和无符号运算 详解

针对能够影响OF和CF标志位的指令&#xff0c;一般来说是涉及到数据运算的指令&#xff0c;这里使用add举例&#xff0c;即不区分有无符号的加法指令&#xff0c;参与运算的数据&#xff0c;从二进制层级去考虑。 CF标志位 对于CF&#xff0c;它是carry flag&#xff0c;进位标…

tmux学习笔记

参考学习链接 我们需要理解几个重要的概念 session 回话window 窗口pane 窗格 window 我们打开的一个terminal就是一个window. 而打开的这个window&#xff0c;也就是打开了一个session&#xff0c;打开window&#xff0c;session开始&#xff1b;关闭window&#xff0c;se…

安装win10和Linux双系统的个人经验

使用easy uefi误删除win10引导文件 这个时候&#xff0c;网上教程有各种方式&#xff0c;我直接使用了一种最简单的&#xff0c;这个方法网上都没有提到过。 注意&#xff1a;发现引导文件删了&#xff0c;千万不要关机&#xff0c;否则再想开机恐怕只能重装系统了。 我们直…

Linux的ext4文件系统学习笔记

补充&#xff1a;设备独立性 Linux中&#xff0c;设备驱动以文件形式表示&#xff0c;用户操作逻辑设备就是操作文件&#xff0c;而不是具体的物理设备&#xff0c;也就是说&#xff0c;用户操作的是功能&#xff0c;是黑箱&#xff0c;而不是真正的实体。 APP操作的都是逻辑…

html基础元素案例笔记(1)

这是代码 <!DOCTYPE html> <html><head><meta charset"utf-8"><title>CSS FlexBox test</title><link rel"stylesheet" type"text/css" href"./css/index.css"></head><body>…

C语言中的struct和union区别

参考&#xff1a;Difference between Structure and Union in C 二者区别 struct 这里不做详细说明&#xff0c;因为参考链接中都写明了。只做一些重点强调。 struct中声明的变量&#xff0c;在分配空间的时候&#xff0c;struct结构空间大小&#xff0c;大于等于其内部所有…

C语言多文件编译链接为1个可执行文件的简单原理

参考1&#xff1a;C header files and compilation/linking 参考2&#xff1a;计算机系统基础&#xff08;一&#xff09;袁春风 &#xff08;符号链接部分&#xff09; 我们现在有一个简单的工程&#xff0c;有这么几个文件 1.t1.h extern int x;void tt();t1.c #include &…

Java读写二维数组到文件

1. 创建文件 使用了File类中的createrNewFile方法。 public static boolean createFile(String filename){try{File file new File(filename);file.createNewFile();return true;} catch (IOException e) {e.printStackTrace();return false;}}查阅文档可知&#xff0c;若文件…