python基础排序和二分查找常用方法

def bubble_sort(alist):

#冒泡排序

n=len(alist)

#设置外层循环,构造内层循环比较条件

for i in range(n-1):

#构造内层循环比较环境

for j in range(n-1-i):

#如果左边元素值大于右边元素值,则交换变量的值

if alist[j]>alist[j+1]:

#交换变量的值

alist[j],alist[j+1]=alist[j+1],alist[j]

选择排序

def select_sort(alist):

#计算列表长度

n=len(alist)

#构造外层循环

for i in range(n-1):

#设置默认值

min_index=i

#构造内层循环;

for j in range(i+1,n):

if alist[j]<alist[min_index]:

min_index=j

#判断是否和默认值一致,如果变化,交换变量值

if min_index !=i:

alist[min_index],alist[i]=alist[i],alist[min_index]

二分查找

def search(alist,item):

#记录索引

first=0

last=len(alist)-1

#构造循环查找条件

while first<=last:

#构造二分中间值

mid=(first+last)//2

if alist[mid]==item:

return True

else:

if item > alist[mid]:

first=mid+1

else:

last=mid-1

#如果没找到,返回false

else:

return False

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值