【数据结构与算法】【小白也能学的数据结构与算法】迭代算法专题

 🎉🎉欢迎光临🎉🎉

🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀

🌟特别推荐给大家我的最新专栏《数据结构与算法:初学者入门指南》📘📘

本专栏纯属为爱发电永久免费!!!

这是苏泽的个人主页可以看到我其他的内容哦👇👇

努力的苏泽icon-default.png?t=N7T8http://suzee.blog.csdn.net

目录

迭代算法,这是一种解决问题的强大工具。通过迭代,我们可以重复应用一组规则或操作来解决复杂的问题。本文将从基础的迭代概念开始,逐步介绍迭代算法的不同应用和技巧

1. 迭代的基础概念

2. 迭代的高级技巧

3. 迭代算法的应用


迭代算法,这是一种解决问题的强大工具。通过迭代,我们可以重复应用一组规则或操作来解决复杂的问题。本文将从基础的迭代概念开始,逐步介绍迭代算法的不同应用和技巧

1. 迭代的基础概念

在计算机科学中,迭代是指通过多次重复应用一组规则或操作来解决问题的方法。它通常与循环结构紧密相关,通过迭代可以逐步改变问题的状态,直到达到所需的结果。

例如,考虑计算一个数组中所有元素的和。使用迭代的方法,我们可以通过循环遍历数组中的每个元素,并将其累加到一个变量中,最终得到总和。

下面是一个使用迭代计算数组元素和的示例代码:

def compute_sum(array):
    total = 0
    for num in array:
        total += num
    return total

# 测试代码
my_array = [1, 2, 3, 4, 5]
result = compute_sum(my_array)
print("The sum of the array is:", result)

在上述示例中,我们定义了一个compute_sum函数,接受一个数组作为输入,并使用迭代的方法计算数组元素的总和。通过循环遍历数组中的每个元素,并将其累加到变量total中,我们最终得到了数组的总和。

2. 迭代的高级技巧

除了基本的迭代概念外,还有一些高级的迭代技巧可以帮助我们解决更复杂的问题。以下是其中几种常见的技巧:

双指针迭代:在某些情况下,我们可以使用两个指针分别指向序列中的不同位置,并根据特定的规则移动这些指针来解决问题。例如,在查找排序数组中的两个数之和等于目标值的问题中,我们可以使用两个指针从序列的两端向中间移动。

def two_sum(nums, target):
    left = 0
    right = len(nums) - 1

    while left < right:
        sum = nums[left] + nums[right]
        if sum == target:
            return [nums[left], nums[right]]
        elif sum < target:
            left += 1
        else:
            right -= 1

    return []

# 测试代码
nums = [2, 7, 11, 15]
target = 9
result = two_sum(nums, target)
print("The two numbers with sum equal to", target, "are:", result)

在上述示例中,我们定义了一个two_sum函数,接受一个排序数组nums和目标值target作为输入。我们使用两个指针leftright分别指向数组的开头和末尾,并根据特定的规则移动这些指针。

如果指针所指的两个数之和等于目标值target,则返回这两个数。如果和小于目标值,则将left指针向右移动一位;如果和大于目标值,则将right指针向左移动一位。通过这种方式,我们逐步缩小搜索范围,直到找到满足条件的两个数或搜索范围为空。

 

迭代与递归的结合:有时候,我们可以将迭代与递归结合使用,以便更好地解决问题。例如,在树的遍历问题中,我们可以使用迭代的方式来模拟递归的过程,从而避免使用递归函数的系统调用开销。

class TreeNode:
    def __init__(self, value):
        self.val = value
        self.left = None
        self.right = None

def preorder_traversal(root):
    if root is None:
        return []

    stack = []
    result = []
    node = root

    while node or stack:
        while node:
            result.append(node.val)
            stack.append(node)
            node = node.left

        node = stack.pop()
        node = node.right

    return result

# 测试代码
root = TreeNode(1)
root.right = TreeNode(2)
root.right.left = TreeNode(3)

result = preorder_traversal(root)
print("The preorder traversal of the tree is:", result)

在上述示例中,我们定义了一个TreeNode类来表示树的节点,其中包含值val、左子节点left和右子节点right

我们使用迭代的方式来实现树的前序遍历。首先,我们定义一个栈stack用于保存待访问的节点。我们从根节点开始,将根节点入栈。然后,不断迭代执行以下步骤:

  • 弹出栈顶节点,并将其值添加到结果列表中。
  • 将栈顶节点的右子节点入栈(如果存在)。
  • 将栈顶节点的左子节点入栈(如果存在)。

通过这种方式,我们模拟了递归的过程,同时避免了使用递归函数的系统调用开销。

 

迭代与动态规划:迭代与动态规划经常结合使用,以解决一些具有最优子结构性质的问题。通过迭代计算和存储子问题的解,我们可以避免重复计算,提高算法效率。

def fibonacci(n):
    if n == 0:
        return 0
    if n == 1:
        return 1

    dp = [0] * (n + 1)
    dp[0] = 0
    dp[1] = 1

    for i in range(2, n + 1):
        dp[i] = dp[i - 1] + dp[i - 2]

    return dp[n]

# 测试代码
n = 6
result = fibonacci(n)
print("The", n, "th Fibonacci number is:", result)

我们使用迭代的方式,通过动态规划来避免重复计算。

我们使用一个数组dp来存储计算过的斐波那契数。首先,我们初始化dp[0]dp[1]分别为0和1。然后,我们从dp[2]开始,通过迭代计算dp[i] = dp[i - 1] + dp[i - 2],直到计算到第n个斐波那契数dp[n]

通过这种方式,我们避免了重复计算,提高了算法效率。

3. 迭代算法的应用

迭代算法在各种数据结构和算法中都有广泛的应用。以下是一些常见的迭代算法应用:

  • 链表和数组的遍历:通过迭代,我们可以逐个访问链表或数组中的元素。

  • 图的遍历:通过迭代,我们可以访问图中的所有节点和边。

  • 排序算法:许多排序算法,如冒泡排序、插入排序和快速排序,都使用了迭代的思想。

  • 搜索算法:许多搜索算法,如深度优先搜索(DFS)和广度优先搜索(BFS),也使用了迭代的方法。

 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

算法之双指针系列1

目录 一&#xff1a;双指针的介绍 1&#xff1a;快慢指针 2&#xff1a;对撞指针 二&#xff1a;对撞指针例题讲述 一&#xff1a;双指针的介绍 在做题中常用两种指针&#xff0c;分别为对撞指针与快慢指针。 1&#xff1a;快慢指针 简称为龟兔赛跑算法&#xff0c;它的基…

【Rust】——猜数游戏

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…

Redisson分布式锁 原理 + 运用 记录

Redisson 分布式锁 简单入门 pom <dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId><version>3.13.6</version></dependency>配置类 package com.hmdp.config;import org.redisson.Redisson;…

「数据结构」八大排序2:快排、归并排序

&#x1f387;个人主页&#xff1a;Ice_Sugar_7 &#x1f387;所属专栏&#xff1a;初阶数据结构 &#x1f387;欢迎点赞收藏加关注哦&#xff01; 八大排序2 &#x1f349;快速排序&#x1f34c;霍尔版本&#x1f34c;挖坑法&#x1f34c;前后指针法 &#x1f349;快排优化&am…

Xray 工具笔记

Xray 官方文档 扫描单个url&#xff08;非爬虫&#xff09; 并输出文件&#xff08;不同文件类型&#xff09; .\xray.exe webscan --url 10.0.0.6:8080 --text-output result.txt --json-output result.json --html-output report.html默认启动所以内置插件 &#xff0c;指定…

CentOS安装MySQL

下载安装MySQL 官网下载MySQL ① 下载&#xff1a;访问链接&#xff1a;MySQL下载 ② 安装&#xff1a;将安装包上传并解压&#xff0c;解压&#xff1a; tar -zxvf mysql-x.x.xx-xxx.tar.gzyum安装MySQL ① 更新yum&#xff1a;sudo yum update ② 下载MySQL的rpm包&#…

CSP-S 2023 密码锁

原文链接&#xff1a;CSP-S 真题第一讲&#xff1a;密码锁 说明&#xff1a;CSDN和公众号文章同步发布&#xff0c;需要第一时间收到最新内容&#xff0c;请关注公众号【比特正传】。 一、题目背景 题目来源&#xff1a;CSP-J 2023年 T2 题目考察点&#xff1a;模拟、枚举 …

政安晨:梯度与导数~示例演绎《机器学习·神经网络》的高阶理解

这篇文章确实需要一定的数学基础&#xff0c;第一次接触的小伙伴可以先看一下我示例演绎这个主题的前两篇文章&#xff1a; 示例演绎机器学习中&#xff08;深度学习&#xff09;神经网络的数学基础——快速理解核心概念&#xff08;一&#xff09;&#xff1a; 政安晨&#…

选择影视行业创业的原因,影视从业者创业成功的秘密

一、教程描述 本套教程是面向影视从业者的创业教程&#xff0c;主讲人将把自己的创业经验、行业观察、成长心得分享给大家。如果你正在创业&#xff0c;这门课可以让你飞速成长、弯道超车。主讲人积累的行业经验&#xff0c;会让你比大多数同行站的更高&#xff0c;看的更宽。…

备战蓝桥杯---数学基础2

学了常见的筛法&#xff0c;让我们看个题&#xff1a; 首先&#xff0c;我们知道欧拉筛复杂度为nlognlogn,这题可以承受&#xff0c;但是空间上存不了&#xff0c;而如果我们枚举1--n^1/2&#xff0c;复杂度不允许。 其实在枚举的方法中&#xff0c;我们只需找出有无在【2&…

「递归算法」:反转链表

一、题目 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5] 输出&#xff1a;[5,4,3,2,1]示例 2&#xff1a; 输入&#xff1a;head [1,2] 输出&#xff1a;[2,1]示例 3&#xff1a…

爬虫系列-web请求全过程剖析

&#x1f308;个人主页: 会编程的果子君 ​&#x1f4ab;个人格言:“成为自己未来的主人~” 上一小节我们实现了一个网页的整体抓取工作&#xff0c;那么本小节&#xff0c;给各位好好剖析一下web请求的全部过程&#xff0c;这样有助于后面我们遇到的各种各样的网站就有了入手…

【Linux】信号概念与信号产生

信号概念与信号产生 一、初识信号1. 信号概念2. 前台进程和后台进程3. 认识信号4. 技术应用角度的信号 二、信号的产生1. 键盘组合键2. kill 命令3. 系统调用4. 异常&#xff08;1&#xff09;观察现象&#xff08;2&#xff09;理解本质 5. 软件条件闹钟 一、初识信号 1. 信号…

【设计模式】23中设计模式笔记

设计模式分类 模板方法模式 核心就是设计一个部分抽象类。 这个类具有少量具体的方法&#xff0c;和大量抽象的方法&#xff0c;具体的方法是为外界提供服务的点&#xff0c;具体方法中定义了抽象方法的执行序列 装饰器模式 现在有一个对象A&#xff0c;希望A的a方法被修饰 …

离线场景下任意文档的在线预览及原样格式翻译,不依赖其他厂商接口非侵入式一行js代码实现网站的翻译及国际化,可配置使用多种翻译语言

离线场景下任意文档的在线预览及原样格式翻译&#xff0c;不依赖其他厂商接口非侵入式一行js代码实现网站的翻译及国际化&#xff0c;可配置使用多种翻译语言。 要实现翻译需要解决以下3个主要问题&#xff1a; 1&#xff09;from&#xff1a;内容本身的语言类型是什么&#xf…

Open CASCADE学习|扫掠

目录 1、BRepPrimAPI_MakePrism Draw Test Harness&#xff1a; C&#xff1a; 2、BRepPrimAPI_MakeRevol Draw Test Harness&#xff1a; C&#xff1a; 3、BRepOffsetAPI_MakePipeShell Draw Test Harness&#xff1a; C&#xff1a; Draw Test Harness&#xff1a;…

node.js+vue企业人事自动化办公oa系统c288a

采用B/S模式架构系统&#xff0c;开发简单&#xff0c;只需要连接网络即可登录本系统&#xff0c;不需要安装任何客户端。开发工具采用VSCode&#xff0c;前端采用VueElementUI&#xff0c;后端采用Node.js&#xff0c;数据库采用MySQL。 涉及的技术栈 1&#xff09; 前台页面…

小程序-云开发 获取用户的openid等信息

说明介绍&#xff1a; 小程序云开发功能来获取用户的openid。 一般在我们需要用到用户登录的时候&#xff0c;通常是需要获取微信小程序的openid的&#xff0c;由于微信的限制&#xff0c;一般我们只能通过后台去调微信的接口&#xff0c;来授权获取&#xff0c;增加了后端开发…

OnlyOffice-8.0版本深度测评

OnlyOffice 是一套全面的开源办公协作软件&#xff0c;不断演进的 OnlyOffice 8.0 版本为用户带来了一系列引人瞩目的新特性和功能改进。OnlyOffice 8.0 版本在功能丰富性、安全性和用户友好性上都有显著提升&#xff0c;为用户提供了更为强大、便捷和安全的文档处理和协作环境…

内网安全-内网穿透

目录 内网渗透 Nc使用详解 Nc监听和探测 Nc传文件 termite内网穿透工具 ssh代理内网穿透 ssh配置socket代理 MSF多级网络穿透 内网渗透 Nc使用详解 Nc监听和探测 Nc传文件 termite内网穿透工具 1、termite 之前叫ew &#xff08;可以进行正向连接&#xff0c;可以…