网站首页 > 技术文章 正文
今天更新的文章是《Python应用实战,用动画生成冒泡排序的过程》。

冒泡排序
冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果它们的顺序错误就把它们交换过来。遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。
用Python实现冒泡排序
现在我们用Python语言来实现一个冒泡排序,这个应该是很简单的,以下是代码,应该很好理解吧。
def bubble_sort(arr):
n = len(arr)
# 遍历所有数组元素
for i in range(n):
# Last i elements are already in place
for j in range(0, n-i-1):
# 遍历数组从0到n-i-1
# 交换如果元素大于下一个元素
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
return arr
# 测试冒泡排序函数
arr = [64, 34, 25, 12, 22, 11, 90, 1, 10, 33]
sorted_arr = bubble_sort(arr)
print("Sorted array is:", sorted_arr)
在这个例子中,bubble_sort 函数接受一个列表 arr 作为参数,并在原地进行排序。函数首先获取列表的长度 n,然后使用两个嵌套的循环来遍历列表中的每个元素。外层循环负责遍历整个列表,内层循环则负责比较相邻的元素并在需要时交换它们。
冒泡排序并不是一个高效的排序算法,尤其是对于大型数据集。它的平均时间复杂度和最坏时间复杂度都是 O(n^2),其中 n 是列表中的元素数量。对于实际应用,通常会选择更高效的排序算法,如快速排序、归并排序或堆排序。
用动画实现冒泡排序
要想用动画的方式实现冒泡排序,首先需要选择一个好用的可视化的第三方Python库,这里我们可以使用 matplotlib 库来创建一个简单的可视化效果。
首先,确保你你的环境已经安装了 matplotlib 库。如果还没有安装,可以通过以下命令安装:
pip install matplotlib
下面我们是直接给出实现的代码,后面我们给出详细的解释。
import matplotlib.pyplot as plt
import matplotlib.animation as animation
def bubble_sort(arr):
n = len(arr)
for i in range(n):
for j in range(0, n-i-1):
if arr[j] > arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
yield arr.copy()
def update(data):
# 更新图形,重新绘制数据
global step_count
for rect, val in zip(bar_rects, data):
rect.set_height(val)
plt.title(f"Step {step_count}")
step_count += 1
data = [64, 34, 25, 12, 22, 11, 90, 1, 10, 33]
fig, ax = plt.subplots()
bar_rects = ax.bar(range(len(data)), data, align="edge")
# 设置初始步数
step_count = 1
# 创建动画对象
anim = animation.FuncAnimation(
fig, update, frames=bubble_sort(data.copy()),
repeat=False, interval=500
)
anim.save('bubble_sort.gif')
来看下生成的效果:

代码解释
上面我们最核心的主要部分是matplotlib库中的FuncAnimation类,这是用于创建动画的类,它允许用户通过指定更新函数和帧生成器函数来生成动画。以下是这个类的接口的参数。
FuncAnimation(fig, func, frames, init_func=None, fargs=None, repeat=False, repeat_delay=0, blit=False, interval=200)
fig:需要绘制动画的图形对象。
func:更新函数,每次动画更新时调用该函数。
frames:帧生成器函数,用于生成动画的每一帧。
init\_func:初始化函数,用于绘制静态内容。
fargs:更新函数`func`的参数。
repeat:是否重复播放动画。
repeat\_delay:重复播放时的延迟时间。
blit:是否仅绘制变化的部分,可以提高动画绘制效率。
interval:每帧的间隔时间(毫秒)。
在上面的示例代码中,我们使用了FuncAnimation方法来创建动画对象,传入了画布对象fig、更新函数update、排序生成器函数bubble_sort(data.copy())、禁止重复播放(repeat=False)、以及每帧间隔500ms(interval=500)。
FuncAnimation方法在后台会不断调用更新函数update和帧生成器函数bubble_sort(data.copy()),并根据每一帧的数据更新图形。
链接:https://juejin.cn/post/7372469848343953442
猜你喜欢
- 2024-12-27 python编程学习系列:求一列数的最大值和最小值
- 2024-12-27 记住这份软件测试八股文还怕不能拿offer?你值得拥有
- 2024-12-27 Python的分支结构和循环结构
- 2024-12-27 5个简单而有效的Python技巧,用于编写更好、更可维护的函数
- 2024-12-27 Python基础之:Python中的模块
- 2024-12-27 写 Python 代码不可不知的函数式编程技术
- 2024-12-27 多种方法在Python中输出斐波那契数列
- 2024-12-27 学好了Python,我们可以实现很多算法了
- 2024-12-27 一套真实的Python面试题,几十个题目汇总
- 2024-12-27 Python 生成器函数:深入理解与应用案例
- 268℃Python短文,Python中的嵌套条件语句(六)
- 267℃python笔记:for循环嵌套。end=""的作用,图形打印
- 265℃PythonNet:实现Python与.Net代码相互调用!
- 261℃Python实现字符串小写转大写并写入文件
- 260℃Python操作Sqlserver数据库(多库同时异步执行:增删改查)
- 120℃原来2025是完美的平方年,一起探索六种平方的算吧
- 100℃Python 和 JavaScript 终于联姻了!PythonMonkey 要火?
- 94℃Ollama v0.4.5-v0.4.7 更新集合:Ollama Python 库改进、新模型支持
- 最近发表
- 标签列表
-
- python中类 (31)
- python 迭代 (34)
- python 小写 (35)
- python怎么输出 (33)
- python 日志 (35)
- python语音 (31)
- python 工程师 (34)
- python3 安装 (31)
- python音乐 (31)
- 安卓 python (32)
- python 小游戏 (32)
- python 安卓 (31)
- python聚类 (34)
- python向量 (31)
- python大全 (31)
- python次方 (33)
- python桌面 (32)
- python总结 (34)
- python浏览器 (32)
- python 请求 (32)
- python 前端 (32)
- python验证码 (33)
- python 题目 (32)
- python 文件写 (33)
- python中的用法 (32)