python笔记2-冒泡排序
前言
面试的时候经常有面试官喜欢问如何进行冒泡排序?这个问题相信能难倒一批英雄好汉,本篇就详细讲解如何用python进行冒泡排序。
一、基本原理
1.概念:
二、交换两个数
1.如果a = 10 , b = 20如何交换两个数呢?
2.实现两个数的交换原理其实很简单,设一个临时变量c就可以了:
>先把a的值传给c,此时c的值就是10了,a的值还是10
>然后把b的值传给a,此时a的值是20,b的值还是20
>最后把c的值传给b, 此时b的值是10
3.python里面交换两个数不用那么复杂,用这个方法就行了:
>a , b = b, a
三、遍历比较相邻的数
1.比如一个队列是:[1, 3, 10, 9, 21, 35, 4, 6]
2.可以做一次遍历,比较相邻的数,前面的数比后面的数大就交换,这样第一次遍历可以把最大的数下沉到最后一个位置
3.为了便于理解,交换过的地方用红色框框圈出来了
四、循环下沉
1.上面的遍历比较只做了一次下沉,把最大的数下沉到最后一个位置了,那接下来就需要把第二大的数,下沉到倒数第二个位置,
依次循环,一直到最小的数在最上面。
2.这里s是先计算li队列的长度,然后把range函数反转了,变成:[7, 6, 5, 4, 3, 2, 1, 0]
五、sort()排序
1.讲真,python里面排序不用这么麻烦,一个函数搞定:sort()
六、参考代码
# coding:utf-8
li = [1, 3, 10, 9, 21, 35, 4, 6]
s = range(len(li))[::-1]
print s
for i in s:
for j in range(i):
if li[j] > li[j + 1]:
li[j], li[j + 1] = li[j + 1], li[j]
# 排序函数
# li.sort()
print li
觉得对你有帮助,就在右下角点个赞吧,感谢!
python接口自动化QQ群:226296743
[[1, 3, 10, 9, 21, 35, 4, 6]
python笔记2-冒泡排序相关推荐
- c++ 冒泡排序_干货|python笔记1-冒泡排序
面试的时候经常有面试官喜欢问如何进行冒泡排序?这个问题相信可以难倒一批的同学,本篇就详细讲解如何用python进行冒泡排序. 基本原理 01概念: 冒泡排序是一种交换排序,它的基本思想是:两两比较相邻 ...
- Python编码实现冒泡排序
Python编码实现冒泡排序 冒泡排序是一种简单的排序算法,它也是一种稳定排序算法.其实现原理是重复扫描待排序序列,并比较每一对相邻的元素,当该对元素顺序不正确时进行交换.一直重复这个过程,直到没有任 ...
- tkinter 笔记: radiobutton 选择按钮(莫烦python笔记)
1 主体框架还是那个主体框架 window = tk.Tk() window.title('my window') window.geometry('500x500') 2 设置tkinter的文字变 ...
- tkinter 笔记:列表部件 listbox (莫烦python 笔记)
1 主体框架 主体框架部分还是 import tkinter as tkwindow = tk.Tk() #创建窗口window.title('my window') #窗口标题window.geo ...
- python笔记: 生成器
元素按照某种算法推算出来,我们在循环的过程中不断推算出后续的元素 不必创建完整的list,从而节省了大量的空间 这种一边循环一遍计算的机制,称之为生成器generator 1 列表生成器 把列表生成式 ...
- python输出字体的大小_Toby的Python笔记 | 预备知识:安装openpyxl学做电子表格
Toby的Python笔记 | 预备知识:安装openpyxl学做电子表格 Python 需要创建和读取excel表里面的数据,需要用 openpyxl 这个包,今天安装好备用. 首先,进入C命令窗口 ...
- python笔记-1(import导入、time/datetime/random/os/sys模块)
python笔记-6(import导入.time/datetime/random/os/sys模块) 一.了解模块导入的基本知识 此部分此处不展开细说import导入,仅写几个点目前的认知即可.其它内 ...
- python慕课笔记_MOOC python笔记(三) 序列容器:字符串、列表、元组
Python Python开发 Python语言 MOOC python笔记(三) 序列容器:字符串.列表.元组 容器概念 容器是Python中的重要概念,分为有序与无序. 有序容器也称为序列类型容器 ...
- python笔记之Cmd模块
python笔记之Cmd模块 Cmd类型提供了一个创建命令行解析器的框架,默认情况下,它使用readline来进行交互式操作.命令行编辑和命令完成.使用cmd创建的命令行解释器循环读取输入的所有行并且 ...
- Python笔记002-列表推导式
Python笔记002-列表推导式 以下是我学习<流畅的Python>后的个人笔记,现在拿出来和大家共享,希望能帮到各位Python学习者. 首次发表于: 微信公众号:科技老丁哥,ID: ...
最新文章
- Window平台实时流媒体
- Thread线程类及多线程
- CCIE-LAB-第五篇-DHCP+DHCP-Realy+DHCP snooping
- 壊小子的学习【日常阅读篇】(三)常规学习类图书
- GPS 校验和 代码_Linux recovery 移除签名校验
- ruby .each_Ruby中带有示例的Array.each方法
- Web Hacking 101 中文版 六、HTTP 参数污染
- vue 指令 v-on
- 【JavaScript】查漏补缺 —数组中filter()方法
- 使用finalize/dispose 模式提高GC性能(翻译)
- html ul标签宽度,css - ul中每个li的不同宽度 - SO中文参考 - www.soinside.com
- 论文阅读-为什么深度卷积神经网络对小目标的变换泛化效果很差?
- [转载] LINUS:利用二级指针删除单向链表
- [转]coolfire黑客入门教程系列之(六)
- vue源码之数据侦测
- 带宽和下载速度的关系
- 使用ntsd命令强制性杀掉进程[微软未开公的密秘]
- [Mac]开启鼠标键
- multiset upper_bound() 与 lower_bound()
- 企业邮箱搭建模式优劣分析
热门文章
- UML/ROSE学习笔记系列一:建模原理、概念
- 【从C到C++学习笔记】内联成员函数/成员函数重载及缺省参数
- 【统计分析】2 地理统计
- java io中file类_java中IO常见的IO流和file类理论总结
- 物理机安装linux系统,物理机安装linux的三种方法
- Java并发编程实战读书笔记(1)
- Flutter之GridView简析
- 每天一点正则表达式积累(四)
- python css selector_使用python处理selenium中的css_selector定位元素的模糊匹配问题
- qt 限制一段时间内对button只能点按一次_299元入手拓牛智能垃圾桶,用第一次想退货,第三天我上瘾了...