基于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,以便加快程序的加载运行. ...
随机推荐
- 10行实现最短路算法——Dijkstra
今天是算法数据结构专题的第34篇文章,我们来继续聊聊最短路算法. 在上一篇文章当中我们讲解了bellman-ford算法和spfa算法,其中spfa算法是我个人比较常用的算法,比赛当中几乎没有用过其他 ...
- leetcode刷题-47全排列2
题目 给定一个可包含重复数字的序列,返回所有不重复的全排列. 思路 其思路与46题完全一致,但是需要与组合总和2题一般,在同一层取出重复元素.因此可以在每一层设置一个set()类型,将访问过的元素放入 ...
- Mybatis项目构建和CURD操作
Mybatis入门 一.使用SqlSession对象创建Dao接口代理对象进行持久化操作 1.使用maven构建java项目 2.修改pom.xml配置,添加所需jar包坐标 <?xml ver ...
- CSS3 RGBA 属性高级用法
这个属性的兼容问题比较简单,IE8已经支持这个属性,IE6和IE7也可以通过hack支持.RGBA和CSS2里的RBG属性差不多,只是RGBA属性多了一个透明度的定义,CSS3标准里对RGBA属性的解 ...
- pyhton:time模块和datetime模块
一.time模块 1.相关定义: time模块时间的表达有3种,时间戳,时间元祖,格式化时间 #时间戳: print(time.time())#获取当前时间戳.时间戳的计算是1970纪元后经过的浮点秒 ...
- [程序员代码面试指南]最长递增子序列(二分,DP)
题目 例:arr=[2,1,5,3,6,4,8,9,7] ,最长递增子序列为1,3,4,8,9 题解 step1:找最长连续子序列长度 dp[]存以arr[i]结尾的情况下,arr[0..i]中的最长 ...
- HTTP协议(二)---请求和响应
HTTP通过请求和响应的交换达成通信. HTTP请求 请求报文由请求行(请求方法.请求URI.协议版本).请求首部字段以及内容实体(可能没有)构成. 下面是一个GET请求,没有内容实体: 下面是 一个 ...
- Linux实战(11):配置PPPOE拨号
前言: 由于需要做网站数据的抓取,普通的固定代理会容易被封禁,所以我们就用PPPOE通过动态拨号换不同的IP地址来解决该问题,下面PPPOE设置的整个方法过程: 移除NetworkManager安装r ...
- CSAPP 第一章 计算机系统漫游
第一章 计算机系统漫游 C语言的起源:(系统级编程的首选) C语言与Unix操作系统关系密切 C语言小而简单:其设计由一个人掌控 C语言是为实践目的设计的:其设计用来实现Unix操作系统 C语言程序编 ...
- java基础之序列化
转载自https://www.cnblogs.com/szlbm/p/5504166.html Java对象表示方式1:序列化.反序列化和transient关键字的作用 平时我们在Java内存中的 ...