python算法有几种?怎样实现?
Admin 2021-08-18 群英技术资讯 1732 次浏览
这篇文章给大家分享的是有关python算法的内容,主要介绍python实现二分查找和选择排序。小编觉得挺实用的,因此分享给大家做个参考,感兴趣的朋友一起跟随小编看看吧。
实现二分查找的python代码如下:
def binary_search(list, item):
low = 0 #最低位索引位置为0
high = len(list)- 1 #最高位索引位置为总长度-1
while low <= high:
mid = (low + high)//2 #检查中间的元素,书上是一条斜杠,我试过加两条斜杠才行
guess = list[mid]#python自动圆整
if guess == item: #找到了元素
return mid
if guess > item: #猜的数字大了,就修改high
high = mid - 1
else: #猜的数字小了,就修改low
low = mid + 1
return None #没有指定的元素
测试代码:
>>> if __name__ == "__main__":#我试过加上好用 my_list=[1,3,5,7,9] print (binary_search(my_list,3))#把binary_search也加上括号 1#表示3的索引位置为1 >>> if __name__ == "__main__": my_list=[1,3,5,7,9] print (binary_search(my_list,0)) None#表示0不在列表中
实现选择排序的python代码如下:
def findSmallest(arr):
smallest = arr[0]
smallest_index =0
for i in range(1,len(arr)):
if arr[i] < smallest:
smallest = arr[i]
smallest_index= i
return smallest_index
def selectionSort(arr):
newArr = []
for i in range(len(arr)):
smallest = findSmallest(arr)
newArr.append(arr.pop(smallest))
return newArr
测试代码:
#样式1,把selcetionSort()作为新的值给arr,打印arr >>> number=[5,3,6,2,10] >>> arr=selectionSort(number) >>> arr [2, 3, 5, 6, 10] #样式2,加上if __name__ == '__main__':(我也不知道啥作用) >>> if __name__ == '__main__': number=[5,3,6,2,10] print(selectionSort(number)) [2, 3, 5, 6, 10] #样式3,直接输出,最简洁 >>> number=[5,3,6,2,10] >>> print(selectionSort(number)) [2, 3, 5, 6, 10]
关于python中实现二分查找和选择排序就介绍到这,上述实例具有一定的参考价值,感兴趣的朋友可以参考学习,希望能对大家有帮助,想要了解更多python算法的相关内容,大家可以关注其他文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
for循环用于迭代序列(即列表、元组、字典、集合或字符串)。for 语句的写法如从对象开始按顺序给变量赋值,元素个数重复这个过程。对象可以是列表(数组)、元组、字符串等。本文将详细讲解Python中for定义迭代方法详解,需要的可以了解一下
pygame模块针对不同的开发需求提供了不同的子模块,例如显示模块、字体模块、混音器模块等,一些子模块在使用之前必须进行初始化,比如字体模块。为了使开发人员能够更简捷地使用pygame, pygame提供了如下两个函数。
通常需要对前端传递过来的参数进行校验,校验的方式有多种,本文主要介绍了Python中rapidjson参数校验实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要介绍了Django中如何使用celery异步发送短信验证码的代码示例,有需要的朋友可以借鉴参考下,希望可以对大家有所帮助
Python基础-集合set,集合(set)是一个无序的不重复元素序列
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008