数据结构编程实践20讲(Python版)—01数组

本文目录

      • 01 数组 array
        • S1 说明
        • S2 举例
        • S3 问题:二维网格中的最小路径
          • 求解思路
          • Python3程序
        • S4 问题:图像左右变换
          • 求解思路
          • Python3程序
        • S5 问题:青蛙过河
          • 求解思路
          • Python3程序

写在前面

数据结构是计算机科学中的一个重要概念,用于组织和存储数据,以便于高效的访问和修改。不同的数据结构适用于不同类型的应用场景,选择合适的数据结构对于算法的性能至关重要。

常见的数据结构可以分为线性和非线性两大类。

  • 线性数据结构包括数组、链表、栈和队列,适合存储顺序关系的数据。数组提供随机访问能力,而链表则在插入和删除操作上更具灵活性。栈和队列分别实现后进先出(LIFO)和先进先出(FIFO)的访问模式。
  • 非线性数据结构包括树和图。树结构(如二叉树、AVL树和B树)用于表示层次关系,广泛应用于搜索和排序。图则用于表示复杂的连接关系,适合网络、社交图等场景。

此外,散列结构(如哈希表和哈希集合)提供了快速的查找和插入操作,字典和集合则用于存储键值对和不重复元素。高级数据结构如Trie和并查集则解决特定问题,如字符串匹配和动态连通性。

该系列中所给的问题并不是最复杂的,同时给的解法的时间复杂度不一定是最优的,因为本系列主要讲解数据结构。

01 数组 array

S1 说明

数组是一种数据结构,用于存储固定大小的元素集合。每个元素在数组中的位置由一个索引(或下标)唯一标识。通常从零开始。数组中的所有元素类型相同,提供随机访问和直接存取的能力。


S2 举例

在Python中,数组可以通过列表、array模块或NumPy库实现。选择哪种实现方式取决于具体的需求,例如数据类型的统一性、性能需求以及可用的库。对于一般的应用,列表通常足够用;而对于科学计算,NumPy数组则提供了更高效的操作。

  • 列表
a = [1, 2, 3, 8, 11]# 多维
b = [[1, 2, 1, -1, -2]]
c = [[1, 2, 1, -1, -2], [1, 2]]
  • 自带的array模块
import array
my_array = array.array('i', [1, 4, 9, 64, 121])  # 'i'表示整型# 多维
rows = 3
cols = 3
multi_array = [array.array('i', [826] * cols) for _ in range(rows)]
  • Numpy库
import numpy as np
my_array1 = np.array([2, 6, 12, 72, 132])# 多维
my_array2 = np.array([[2, 6, 12, 72, 132], [0, 2, 6, 56, 110]])

S3 问题:二维网格中的最小路径

给定一个 m × n m\times n m×n 的网格 g r i d grid grid,其中 g r i d [ i ] [ j ] grid[i][j] grid[i][j]表示到达该位置的代价。需要找到从 ( 0 , 0 ) (0, 0) (0,0) ( m − 1 , n − 1 ) (m-1, n-1) (m1,n1)的最小路径和,只能往下、右两个方向移动。现有网格如下:
在这里插入图片描述

求解思路
  1. 题目中的网格代价可以用二维数组表示:
grid_cost = [[3, 2, 2, 1], [4, 3, 1, 2], [1, 2, 4, 2], [3, 2, 3, 2]]
  1. 利用动态规划算法求解:
  • 状态定义:定义 d p [ i ] [ j ] dp[i][j] dp[i][j]为到达 ( i , j ) (i, j) (i,j)的最小路径和
  • 状态转移:从上方和左方转移到 ( i , j ) (i, j) (i,j),因此
    d p [ i ] [ j ] = g r i d [ i ] [ j ] + m i n ( d p [ i − 1 ] [ j ] , d p [ i ] [ j − 1 ] ) dp[i][j]=grid[i][j]+min(dp[i−1][j],dp[i][j−1]) dp[i][j]=grid[i][j]+min(dp[i1][j],dp[i][j1])
  • 边界条件
    • 起始点: d p [ 0 ] [ 0 ] = g r i d [ 0 ] [ 0 ] dp[0][0] = grid[0][0] dp[0][0]=grid[0][0]
    • 第一行(根据条件,只能从左边过来): d p [ 0 ] [ j ] = d p [ 0 ] [ j − 1 ] + g r i d [ 0 ] [ j ] dp[0][j] = dp[0][j - 1] + grid[0][j] dp[0][j]=dp[0][j1]+grid[0][j]
    • 第一列(根据条件,只能从上边过来): d p [ i ] [ 0 ] = d p [ i − 1 ] [ 0 ] + g r i d [ i ] [ 0 ] dp[i][0] = dp[i - 1][0] + grid[i][0] dp[i][0]=dp[i1][0]+grid[i][0]
  • 结果:最终的结果为 d p [ m − 1 ] [ n − 1 ] dp[m-1][n-1] dp[m1][n1]
Python3程序
def minPathSum(grid):m, n = len(grid), len(grid[0])dp = [[0] * n for _ in range(m)]  # 存储最小路径和dp[0][0] = grid[0][0]# 初始化第一行for j in range(1, n):dp[0][j] = dp[0][j - 1] + grid[0][j]# 初始化第一列for i in range(1, m):dp[i][0] = dp[i - 1][0] + grid[i][0]# 填充 dp 表for i in range(1, m):for j in range(1, n):dp[i][j] = min(dp[i - 1][j], dp[i][j - 1]) + grid[i][j]# 获取最小路径和min_sum = dp[m - 1][n - 1]return min_sum# 示例输入
grid_cost = [[3, 2, 2, 1],[4, 3, 1, 2],[1, 2, 4, 2],[3, 2, 3, 2]
]min_sum  = minPathSum(grid_cost)
print(f"最小路径和: {min_sum}")# 最小路径和: 14
S4 问题:图像左右变换

给定一张图片,实现该图片的左右互换。
在这里插入图片描述

求解思路
  1. 用PIL包读取RGB模式的图片,然后利用numpy获得三维数组
  2. 可利用 l e f t _ p i x e l , r i g h t _ p i x e l = r i g h t _ p i x e l , l e f t _ p i x e l left\_pixel, right\_pixel = right\_pixel, left\_pixel left_pixel,right_pixel=right_pixel,left_pixel实现左右像素互换
  3. 三维数组利用matplotlib可视化
Python3程序
import numpy as np
from PIL import Image
import matplotlib.pyplot as pltdef flip_image_horizontally(imagepath):original_image = Image.open(imagepath).convert('RGB')# 读取为RGBrgb_data = np.array(original_image).transpose([2, 0, 1])challels, rows, cols = rgb_data.shape# 读取三维数组for c in range(challels):for i in range(rows):for j in range(cols // 2):# 交换左右像素的 RGB 值rgb_data[c][i][j], rgb_data[c][i][cols - 1 - j] = (rgb_data[c][i][cols - 1 - j], rgb_data[c][i][j])# 可视化plt.imshow(rgb_data.transpose([1, 2, 0]))plt.axis('off')plt.show()if __name__ == '__main__':imagepath = '你的图片路径'flip_image_horizontally(imagepath)

在这里插入图片描述

S5 问题:青蛙过河

一只青蛙想要过河。 假定河流被等分为若干个单元格,并且在每一个单元格内有可能放有一块石子,也有可能没有。

现给你石子的位置列表 s t o n e s stones stones(用单元格序号表示), 请判定青蛙能否成功过河(青蛙可以跳上石子,但是不可以跳入水中)即能否在最后一步跳至最后一块石子上。开始时, 青蛙默认已站在第一块石子上,并可以假定它第一步只能跳跃 1 个单位(即只能从单元格 1 跳至单元格 2 )。

如果青蛙上一步跳跃了 k k k个单位,那么它接下来的跳跃距离只能选择为 k − 1 、 k k - 1、k k1k k + 1 k + 1 k+1个单位。 另请注意,青蛙只能向前方(终点的方向)跳跃。

例如:给定 s t o n e s = [ 0 , 1 , 3 , 5 , 6 , 8 , 12 , 17 ] stones = [0,1,3,5,6,8,12,17] stones=[0,1,3,5,6,8,12,17],具体见下图:

在这里插入图片描述
按照如下方案跳跃:跳 1 个单位到第 2 块石子(位置1), 然后跳 2 个单位到第 3 块石子(位置3), 接着 跳 2 个单位到第 4 块石子(位置5), 然后跳 3 个单位到第 6 块石子(位置8), 跳 4 个单位到第 7 块石子(位置12), 最后,跳 5 个单位到第 8 个石子(即最后一块石子,位置17)。

求解思路
  1. 利用深度优先搜索(DFS)结合记忆化来解决这个问题
  • 状态表示
    使用一个递归函数 dfs(position, k),其中 position 是青蛙当前所在的位置,k 是上一次的跳跃距离。
  • 终止条件
    如果 position 是最后一块石头的位置,返回 True。
  • 递归
    • 对于每一次跳跃,尝试 k - 1、k 和 k + 1 的跳跃距离。
    • 检查新位置是否在 stones 中,并且是否可以到达。
  • 记忆化
    使用一个字典来存储已经访问过的状态,以避免重复计算。
Python3程序
def canCross(stones):stone_set = set(stones)memo = {}# DFS深度优先搜索def dfs(position, k):# 判断终止条件if position == stones[-1]:return True# 判断这个位置是否来过,并且是不是可以到达的if (position, k) in memo:return memo[(position, k)]# 遍历可能的跳跃单位for jump in [k - 1, k, k + 1]:if jump > 0:next_position = position + jump# 有石头,并且可到达if next_position in stone_set and dfs(next_position, jump):# 存储已经访问过的状态memo[(position, k)] = Truereturn Truememo[(position, k)] = Falsereturn Falsereturn dfs(stones[0], 0)if __name__ == '__main__':stones = [0, 1, 3, 5, 6, 8, 12, 17]print(canCross(stones))

结果

True

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

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

相关文章

使用Plotly绘制交互式图表:从入门到精通

使用Plotly绘制交互式图表:从入门到精通 在数据科学和数据可视化领域,交互式图表能够提供更丰富的用户体验和更深入的数据洞察。Plotly 是一个强大的 Python 库,它不仅支持静态图表,还能创建高度交互的图表。本文将详细介绍如何使用 Plotly 实现一个函数来绘制交互式图表,…

【Gitee自动化测试2】Git,Github,Gitlab,Gitee

一. 服务器 与 客户端 是提供服务的计算机,存储项目代码和版本信息,处理客户端请求并返回响应。并通过网络向其他计算机(即客户端)提供这些服务。服务器可以是物理设备,也可以是虚拟机。 二. 版本控制 目的&#xf…

HttpSession使用方法及原理

HttpSession使用方法及原理 一、HttpSession使用流程说明二、登录概述具体 三、访问过程概述具体 一、HttpSession使用流程说明 1.用户发送登录请求到服务器。 2.服务器处理登录请求,调用userService.login(loginUser)。 3.如果登录成功,服务器调用requ…

Linux云计算 |【第四阶段】NOSQL-DAY2

主要内容: Redis集群概述、部署Redis集群(配置manage管理集群主机、创建集群、访问集群、添加节点、移除节点) 一、Redis集群概述 1、集群概述 所谓集群,就是通过添加服务器的数量,提供相同的服务,从而让…

【echarts】报错series.render is required.

总结:就是echarts无法保存renderItem函数到json里,因为renderItem是个封装方法,因此需要初始化加载时重新插入renderItem即可 1.描述:控制台报错series.render is required. 原数据json如下: {type: "bar"…

‌[AI问答] Auto-sklearn‌ 与 scikit-learn 区别

‌Auto-sklearn与scikit-learn的主要区别在于Auto-sklearn是一个自动化机器学习库,而scikit-learn是一个用于数据挖掘和数据分析的Python工具包。‌ Auto-sklearn是一个自动化的机器学习工具,它能够自动搜索最佳的学习算法并优化其超参数,通…

SQLAlchemy 查询,多条件的查询需求,根据传入条件的实际情况,决定将哪些条件作为filter条件进行查询

多个条件的查询,使用 SQLAlchemy 的查询构建器来动态地构建查询,根据传入的条件参数(condition1, condition2, condition3 等)来决定是否将这些条件添加到查询中 class Order(Base): __tablename__ orders id Column(Integer,…

Python--循环

在Python中&#xff0c;while循环和for循环的语法如下&#xff1a; 1. while循环 while循环会在给定条件为真时重复执行代码块。其基本语法如下&#xff1a; while 条件:# 执行的代码块示例&#xff1a; count 0 while count < 5:print(count)count 12. for循环 for循…

工作安排 - 华为OD统一考试(E卷)

2024华为OD机试(C卷+D卷)最新题库【超值优惠】Java/Python/C++合集 题目描述 小明每周上班都会拿到自己的工作清单,工作清单内包含n项工作,每项工作都有对应的耗时时长(单位h)和报酬,工作的总报酬为所有已完成工作的报酬之和。那么请你帮小明安排一下工作,保证小明在指定…

科研绘图系列:R语言树结构聚类热图(cluster heatmap)

文章目录 介绍加载R包导入数据数据预处理画图修改图形导出数据系统信息介绍 热图结合树结构展示聚类结果通常用于展示数据集中的模式和关系,这种图形被称为聚类热图或层次聚类热图。在这种图中,热图部分显示了数据矩阵的颜色编码值,而树结构(通常称为树状图或聚类树)则显…

AIGAME背后的强大背景与AI币价值的崛起

AIGAME平台背后汇集了强大的资本和技术支持&#xff0c;凭借蒙特加密产业基金的战略投资和汇旺集团的多元化Web3基础设施建设&#xff0c;AIGAME在全球范围内迅速崛起。平台所使用的Sleepless AI技术&#xff0c;结合区块链与AI的深度融合&#xff0c;赋能AI币&#xff0c;使其…

虚拟社交的新时代:探索Facebook的元宇宙愿景

随着技术的不断进步&#xff0c;社交媒体的形态也在悄然变化。Facebook&#xff08;现名Meta&#xff09;正站在这一变革的前沿&#xff0c;积极探索元宇宙的愿景。元宇宙不仅是虚拟现实&#xff08;VR&#xff09;和增强现实&#xff08;AR&#xff09;的结合&#xff0c;更是…

遍历9个格子winmine!StepBlock和遍历8个格子winmine!StepBox的对决

遍历9个格子winmine!StepBlock和遍历8个格子winmine!StepBox的对决 第一部分&#xff1a;windbg调试记录。 0: kd> g Breakpoint 10 hit winmine!DoButton1Up: 001b:0100390e a130510001 mov eax,dword ptr [winmine!xCur (01005130)] 0: kd> kc # 00 winmine…

LLaMA-Factory 使用 alpaca 格式的数据集

LLaMA-Factory 使用 alpaca 格式的数据集 flyfish alpaca 格式最初与Stanford大学的一个研究项目相关联&#xff0c;该项目旨在通过少量高质量的数据来微调大型语言模型。它受到了Alpaca模型&#xff08;一种基于LLaMA的指令跟随模型&#xff09;的影响&#xff0c;该模型是在…

Python 入门教程(3)基础知识 | 3.7、pass 关键字

文章目录 一、pass 关键字1、定义与用法2、pass 关键字的用法2.1、函数定义中的占位符2.2、 类定义中的占位符2.3、条件语句中的占位符2.4、循环中的占位符 3、注意事项 一、pass 关键字 1、定义与用法 pass语句用作将来代码的占位符。当执行pass语句时&#xff0c;不会有任何…

【RabbitMQ 项目】服务端:服务器模块

文章目录 一.编写思路二.代码实践三.服务端模块关系总结 一.编写思路 成员变量&#xff1a; muduo 库中的 TCP 服务器EventLoop 对象&#xff1a;用于主线程循环监控连接事件协议处理句柄分发器&#xff1a;用于初始化协议处理器&#xff0c;便于把不同请求派发给不同的业务处理…

【FastAPI】使用FastAPI和Redis实现实时通知(SSE)

在当今快速发展的Web应用程序中&#xff0c;实时通知已成为用户体验的重要组成部分。无论是社交媒体更新、消息通知&#xff0c;还是系统状态提醒&#xff0c;实时数据推送可以极大地提升用户互动性。本文将详细介绍如何使用FastAPI和Redis实现Server-Sent Events (SSE) 来推送…

模拟电路工程师面试题

一、基础知识题 描述三极管的基本工作原理及其三种工作状态。 分析:此题考察对三极管(NPN或PNP)基本工作原理的理解,包括截止区、放大区和饱和区的特点及其条件。解释什么是反馈,并说明正反馈和负反馈的区别。 分析:反馈是放大器设计中的重要概念,正反馈会增加放大器的增…

【AI】简单了解AIGC与ChatGPT

● AIGC&#xff08;AI-Generated Content&#xff0c;人工智能生成内容&#xff09;指的是利用人工智能技术自动生成内容&#xff0c;包括文本、图像、音频、视频等。AIGC的应用非常广泛。AIGC的核心在于利用AI技术来创造新的内容&#xff0c;提高生产效率&#xff0c;降低成本…

java mybaits oracle插入返回主键

在MyBatis中&#xff0c;要实现在插入数据后返回主键&#xff0c;可以在Mapper的XML文件中使用useGeneratedKeys属性和keyProperty属性。以下是一个示例&#xff1a; 首先&#xff0c;确保你的Oracle表有一个可以自动生成主键的字段&#xff0c;比如使用Oracle的序列。 CREAT…