首页 > 编程语言 >Python冒泡排序算法

Python冒泡排序算法

时间:2023-11-14 15:33:20浏览次数:34  
标签:arr 遍历 Python 元素 冒泡排序 算法 数组 排序

冒泡排序算法是一种简单的排序算法,其基本思想是通过多次遍历数组,比较相邻的两个元素,如果它们的顺序不对则交换。这样一轮遍历之后,最大(或最小)的元素就会被移动到数组的最后,然后再对剩余的元素进行类似的操作,直到整个数组有序

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]

示例

arr = [64, 34, 25, 12, 22, 11, 90] bubble_sort(arr)

print("排序后的数组:", arr)

标签:arr,遍历,Python,元素,冒泡排序,算法,数组,排序
From: https://blog.51cto.com/u_16352270/8370018

相关文章

  • 【Python】爬虫代理IP的使用+建立代理IP池
    前言在进行网络爬虫开发时,我们很容易遭遇反爬虫机制的阻碍。为了规避反爬虫机制,我们可以使用代理IP。代理IP是指通过代理服务器获取的可用于访问目标网站的IP地址,通过使用代理IP,我们可以隐藏自己的真实IP地址,避免被目标网站封禁。但是,在使用代理IP时,我们需要注意一些问题:代理IP的质......
  • Python函数参数传递中的可变参数
    Python函数参数传递中*args和**kargs在Python中,*args和**kwargs是用于处理可变数量的参数的特殊语法。*args:*args是一个元组(tuple),它允许你将不定数量的非关键字参数传递给函数。这意味着你可以在函数定义时指定一些参数,同时允许调用函数时传递不同数量的参数。通常用*......
  • 《最新出炉》系列初窥篇-Python+Playwright自动化测试-27-处理单选和多选按钮-番外篇
    1.简介前边几篇文章是宏哥自己在本地弄了一个单选和多选的demo,然后又找了网上相关联的例子给小伙伴或童鞋们演示了一下如何使用playwright来处理单选按钮和多选按钮进行自动化测试,想必大家都已经掌握的八九不离十了吧。这一篇其实也很简单:就是宏哥在网上找了一个问卷调查例子......
  • 代码随想训练营第三十五天打卡(Python)| 860.柠檬水找零、406.根据身高重建队列、452. 用
    860.柠檬水找零classSolution:deflemonadeChange(self,bills:List[int])->bool:five,ten,twenty=0,0,0forbillinbills:ifbill==5:five+=1elifbill==10:iffive......
  • Python离线引入第三方库
    1、将已安装的软件包名称输入到requirements.txt文件中,命令如下pipfreeze>requirements.txt2、在需要下载包的目录下,放入requirements.txt文件,打开cmd命令,执行命令如下:pipdownload-rrequirements.txt-dpackages3、把packages文件夹复制到内网计算机的项目根目录下,执行如......
  • Python速成计划
    目标:帮助零基础学员快速掌握Python编程语言,能够在实际应用中灵活运用Python解决实际问题。学习周期:1个月(以每周5天,每天2小时的学习时间计算)。学习内容:Python基础语法和变量定义(1周)学习内容:了解Python语言的特点,掌握Python的基本语法,包括变量定义、数据类型、条件语句、循环语句......
  • python 检查一个字符串路径(该路径实际不存在) 是文件路径还是文件夹路径
    importosdefguess_path_type(path):base_name=os.path.basename(path)if'.'inbase_name:return"Probablyafilepath"else:return"Probablyadirectorypath"#测试print(guess_path_type(......
  • 1822_使用python内置的库进行日期序列的生成
    使用python的内置的库进行日期序列的生成用到的库介绍datetime实现这样的功能其实只需要这一个库就够了,但是网络上找到的例程很多都额外增加了对time库的引用。只能说,这样不会出现错误,但是这样肯定会有一些计算资源上的消耗。#!/usr/bin/python3importdatetimestart_date=......
  • 反向传播算法代码
    importtorchimporttorch.nnasnnimporttorch.optimasoptimclassMLPModel(nn.Module):def__init__(self,input_size):super(MLPModel,self).__init__()self.fc1=nn.Linear(input_size,128)self.fc2=nn.Linear(128,64)......
  • 11.14算法
    题目岛屿数量给你一个由 '1'(陆地)和'0'(水)组成的的二维网格,请你计算网格中岛屿的数量。岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。此外,你可以假设该网格的四条边均被水包围。示例1:输入:grid=[["1","1","1","1","0"],["1","1"......