基于python常用排序与查找
"""
排序与查找
-- 冒泡排序
-- 选择排序
-- 快速排序 --****经典
-- 希尔排序
"""
# 常用排序的实现 # 冒泡排序-每轮排出最大 时间复杂度O(n**2)
def bubble(list_):
if list_: # 非空列表排序
# 外层表示比较轮数
for i in range(len(list_)-1):
# 表示每轮两两比较的次数
for j in range(len(list_)-1-i):
if list_[j] > list_[j+1]:
list_[j],list_[j+1] = list_[j+1],list_[j]
else: # 空列表报异常
raise ValueError # 选择排序
def select_sort(list_):
# 外侧循环n-1轮
for i in range(len(list_)-1):
# 假设list_[i]最小
min = i
for j in range(i+1,len(list_)):
if list_[min] > list_[j]:
# 擂主换人
min = j
#进行交换,将最小值换到应该在的位置
if min != i:
list_[i],list_[min] = list_[min],list_[i] # 插入排序
def insert_sort(list_):
# 外侧循环n-1轮,每次比较的数,从第二个数开始
for i in range(1,len(list_)):
# 空出list_[i]的位置
x = list_[i]
j = i-1
while j >= 0 and list_[j] > x:
list_[j+1] = list_[j]
j -= 1
list_[j +1] = x # 完成一轮交换
def sub_sort(list_,low,high):
# 选定基准
x = list_[low]
# low 向后,high向前
while low < high:
# 后面的数前放
while list_[high] >= x and high > low:
high -= 1
list_[low] = list_[high]
# 前面数后放
while list_[low] < x and low < high:
low += 1
list_[high] = list_[low]
list_[low] = x # 快速排序(升序) # low,high = 0,len(list01)-1
# low表示列表的第一个元素索引,high表示最后一个元素索引
def quick_sort(list_,low,high):
"""
1.取出0号元素,赋值,从列表尾部开始比较,
只要比较出比该值小的,被比较的值放头部,
赋值值放那个移动额位置
2.因第一次比较,分出大于原0号元素和小于0号
元素的两部分数,两部分数分别重复1,2
3.直到比较完,结束
:return:
"""
if low < high:
sub_sort(list_,low,high) #快排的主函数,传入参数为一个列表,左右两端的下标
def QuickSort(list,low,high):
if high > low:
#传入参数,通过Partitions函数,获取k下标值
k = Partitions(list,low,high)
#递归排序列表k下标左侧的列表
QuickSort(list,low,k-1)
# 递归排序列表k下标右侧的列表
QuickSort(list,k+1,high) def Partitions(list,low,high):
left = low
right = high
#将最左侧的值赋值给参考值k
k = list[low]
#当left下标,小于right下标的情况下,此时判断二者移动是否相交,若未相交,则一直循环
while left < right :
#当left对应的值小于k参考值,就一直向右移动
while list[left] <= k:
left += 1
# 当right对应的值大于k参考值,就一直向左移动
while list[right] > k:
right = right - 1
#若移动完,二者仍未相遇则交换下标对应的值
if left < right:
list[left],list[right] = list[right],list[left]
#若移动完,已经相遇,则交换right对应的值和参考值
list[low] = list[right]
list[right] = k
#返回k值
return right # 二分查找(有序数组)
def binary_search(list_,key):
low, high = 0,len(list_)-1
# 判断条件
while low < high:
mid = (low+high) // 2
if list_[mid] < key:
low = mid + 1
elif list_[mid] > key:
high = mid -1
else:
return mid list02 = [1,2,3,4,5,6,7,8,9,10]
print("key index:",binary_search(list02,8)) # list_demo = [6,1,2,7,9,3,4,5,10,8]
# print(list_demo)
# QuickSort(list_demo,0,9)
# print(list_demo) #----------------------------
# if __name__ == "__main__":
# print("-"*30)
# list01 = [5,2,57,12,4,9,40,25,3]
# # bubble(list01)
# #print(list01)
# print(sub_sort(list01,0,8))
# print(list01)
基于python常用排序与查找的更多相关文章
- 第四百一十五节,python常用排序算法学习
第四百一十五节,python常用排序算法学习 常用排序 名称 复杂度 说明 备注 冒泡排序Bubble Sort O(N*N) 将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮 ...
- Python常用排序算法
1.冒泡排序 思路:将左右元素两两相比较,将值小的放在列表的头部,值大的放到列表的尾部 效率:O(n²) def bubble_sort(li): for i in range(len(li)-1): ...
- C#常用排序和查找算法
1.C#堆排序代码 private static void Adjust (int[] list, int i, int m) { int Temp = list[i]; int j = i * 2 ...
- 常用排序算法的python实现和性能分析
常用排序算法的python实现和性能分析 一年一度的换工作高峰又到了,HR大概每天都塞几份简历过来,基本上一天安排两个面试的话,当天就只能加班干活了.趁着面试别人的机会,自己也把一些基础算法和一些面试 ...
- Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法
Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...
- Python实现常用排序算法
Python实现常用排序算法 冒泡排序 思路: 它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完 ...
- 基于python对B站收藏夹按照视频发布时间进行排序
基于python对B站收藏夹按照视频发布时间进行排序 前言 在最一开始,我的B站收藏一直是存放在默认收藏夹中,但是随着视频收藏的越来越多,没有分类的视频放在一起,想在众多视频中找到想要的视频非常困难, ...
- 基于python的opcode优化和模块按需加载机制研究(学习与个人思路)(原创)
基于python的opcode优化和模块按需加载机制研究(学习与思考) 姓名:XXX 学校信息:XXX 主用编程语言:python3.5 个人技术博客:http://www.cnblogs.com/M ...
- Python学习之路【第二篇】-pyc简介、Python常用的数据类型及其用法和常用运算符
1.pyc简介 python程序在运行时也有编译过程,编译后会产生.pyc文件.这是一种由python虚拟机执行的二进制文件(字节码),用于保存内存中PyCodeObject,以便加快程序的加载运行. ...
随机推荐
- ubuntu18.04 docker安装mongo
问题 在docker中安装的mongo连接不上,报错信息 feng@ubuntu:/etc/docker$ mongo MongoDB shell version v3.6.3 connecting ...
- mac如何安装YaPi
首先介绍一下YaPi是干什么的. 帮助开发者轻松创建.发布.维护 API,YApi 还为用户提供了优秀的交互体验,开发人员只需利用平台提供的接口数据写入工具以及简单的点击操作就可以实现接口的管理.免费 ...
- mysql 5.7密码策略和安装密码校验插件validate_password
当执行sql:SHOW VARIABLES LIKE 'validate_password%';提示empty,说明没有安装密码插件 1.查看当前mysql安装的插件信息 mysql> show ...
- 循环删除list的方法
错误的方法: 正确的方法:
- spring cloud微服务快速教程之(十二) 分布式ID解决方案(mybatis-plus篇)
0-前言 分布式系统中,分布式ID是个必须解决的问题点: 雪花算法是个好方式,不过不能直接使用,因为如果直接使用的话,需要配置每个实例workerId和datacenterId,在微服务中,实例一般动 ...
- HBase shell的使用记录
1. list命令 该命令列出hbase中所有的表 hbase(main):007:0* list TABLE SYSTEM:CATALOG SYSTEM:FUNCTION SYSTEM:MUTEX ...
- netty字节分包
高并发压测时,发现来自网关的消息出现粘包现象:分包就是势在必行的 前置和处理平台(暂时)使用netty通话,由于都是服务器平台使用DelimiterBasedFrameDecoder来解决分包 和网关 ...
- hystrix(5) 延时检测
hystrix在执行命令的同事,会对执行延时进行检测,如果超过设置的延时时间,那么将停止执行,并返回fallback执行结果. if (properties.executionTimeoutEnabl ...
- cas机制的原理和使用
一.什么是cas CAS,compare and swap的缩写,中文翻译成比较并交换. CAS 操作包含三个操作数 -- 内存位置(V).预期原值(A)和新值(B). 如果内存位置的值与预期原值相匹 ...
- Oracle学习(十一)聚合函数
AVG() 求平均数 --查询某列的平均值 SELECT AVG(列) FROM 表 COUNT()查询条数 -- 查询所有记录的条数 select count(*) from 表; -- 查询对应列 ...