python实现折半查找和归并排序算法
作者:前程明亮 发布时间:2023-06-24 00:08:01
今天依旧是学算法,前几天在搞bbs项目,界面也很丑,评论功能好像也有BUG。现在不搞了,得学下算法和数据结构,笔试过不了,连面试的机会都没有……
今天学了折半查找算法,折半查找是蛮简单的,但是归并排序我就挺懵比,看教材C语言写的归并排序看不懂,后来参考了别人的博客,终于搞懂了。
折半查找
先看下课本对于 折半查找的讲解。注意了,折半查找是对于有序序列而言的。每次折半,则查找区间大约缩小一半。low,high分别为查找区间的第一个下标与最后一个下标。出现low>high时,说明目标关键字在整个有序序列中不存在,查找失败。
看我用python编程实现:
def BinSearch(array, key, low, high):
mid = int((low+high)/2)
if key == array[mid]: # 若找到
return array[mid]
if low > high:
return False
if key < array[mid]:
return BinSearch(array, key, low, mid-1) #递归
if key > array[mid]:
return BinSearch(array, key, mid+1, high)
if __name__ == "__main__":
array = [4, 13, 27, 38, 49, 49, 55, 65, 76, 97]
ret = BinSearch(array, 76, 0, len(array)-1) # 通过折半查找,找到65
print(ret)
输出: 在列表中查找76.
76
时间复杂度:O(logn)
归并排序算法
先阐述一下排序思路:
首先归并排序使用了二分法,归根到底的思想还是分而治之。归并排序是指把无序的待排序序列分解成若干个有序子序列,并把有序子序列合并为整体有序序列的过程。长度为1的序列是有序的。因此当分解得到的子序列长度大于1时,应继续分解,直到长度为1.
(下图是分解过程,图自python编程实现归并排序)
合并的过程如下:
很好,你现在可以和别人说,老子会归并排序了。但是让你写代码出来,相信你是不会的……
来来来,看我用python写的归并排序算法:
def merge_sort(array): # 递归分解
mid = int((len(array)+1)/2)
if len(array) == 1: # 递归结束的条件,分解到列表只有一个数据时结束
return array
list_left = merge_sort(array[:mid])
list_right = merge_sort(array[mid:])
print(">>>list_left:", list_left)
print(">>>list_right:", list_right)
return merge(list_left, list_right) # 进行归并
def merge(list_left, list_right): # 进行归并
final = []
while list_left and list_right:
if list_left[0] <= list_right[0]: # 如果将"<="改为"<",则归并排序不稳定
final.append(list_left.pop(0))
else:
final.append(list_right.pop(0))
return final+list_left+list_right # 返回排序好的列表
if __name__=="__main__":
array = [49, 38, 65, 97, 76]
print(merge_sort(array))输出:
输出:
>>>list_left: [49]
>>>list_right: [38]
>>>list_left: [38, 49]
>>>list_right: [65]
>>>list_left: [97]
>>>list_right: [76]
>>>list_left: [38, 49, 65]
>>>list_right: [76, 97]
[38, 49, 65, 76, 97]
时间度杂度: 平均情况=最好情况=最坏情况=O(nlogn)
空间复杂度: O(n)
稳定性: 稳定
对序列{ 6, 5, 3, 1, 8, 7, 2, 4 }进行归并排序的实例如下:
使用归并排序为一列数字进行排序的宏观过程:


猜你喜欢
- 简介:ssh是一个协议,OpenSSH是其中一个开源实现,paramiko是Python的一个库,实现了SSHv2协议(底层使用crypto
- 一、功能分析简单分析一下网站的功能,大致如下:需要用户在地址栏中提交参数,根据参数中的id查询对应的用户信息。如果id存在,则显示查询成功,
- 【原文地址】My "First Look at Orcas" Presentation 【原文发表日期】 Th
- 如果直接从生成验证码的页面把验证码下载到本地后识别,再构造表单数据发送的话,会有一个验证码同步的问题,即请求了两次验证码,而识别出来的验证码
- javascript:a. 代码:/*@desc:js搜索函数,可用于关键字匹配@param key 关键字@param str 要搜索的字
- 具体方法:首先打开命令提示符;然后执行【mysql -u root -p】命令进入mysql;最后执行如下命令即可:select SUBST
- 主程序mainaddfunc.pyfrom flask import Flask, render_template, request, ur
- 如下所示:import rec = re.compile(r'\d')s = 'you1are2welcome
- 一般情况下,mysql会默认提供多种存储引擎,可以通过下面的查看:1)查看mysql是否安装了innodb插件。通过下面的命令结果可知,已经
- 当前的实践中问题在项目之间依赖的时候我们往往可以通过mock一个接口的实现,以一种比较简洁、独立的方式,来进行测试。但是在mock使用的过程
- list.asp<%@LANGUAGE="VBSCRIPT" CODEPAGE="936&qu
- 下边我就简单说一下过程和原理。第一步:实现一个匿名函数并能自己执行。(function(){ })() 这个函数在一样编的好的J
- 春节来到,红包们大概率在微信各大群中肆虐,大家是否都一样不抢到红包们心里就感觉错过了一个亿,可总会被这事那事耽误而遗憾错过,下面用 Pyth
- 来自Six Revisions的一篇文章,作者对一些主流的浏览器进行了测试比较,测试主要针对以下几个方面进行:1.JavaScript执行速
- 需求:需要在pycharm中跑一个深度学习的项目但是tensorflow包导不入问题分析:当前使用的是anaconda的3.8版本,无法正常
- 下载Git安装文件:GIt官网下载地址:Git-2.6.3-64-bit.exe然后就进入了Git的安装界面,如图:Git安装界面和Node
- 自定义序列的相关魔法方法允许我们自己创建的类拥有序列的特性,让其使用起来就像 python 的内置序列(dict,tuple,list,st
- 本文详细介绍了Python中类型关系和继承关系。分享给大家供大家参考。具体分析如下:如果一个对象A持有另一个对象B的ID,那么检索到A之后就
- 0 前言安装:pip install pypiwin32 1 Excel的APIimport win32com.client as win3
- 一、简述MySQL版本从5直接 * 到8,相信MySQL8一定会有很多令人意想不到的改进,如果不想只会CRUD可以看看。比如系统表引擎的变化