选择排序、插入排序、冒泡排序python实现

选择排序、插入排序、冒泡排序python实现

选择排序的时间复杂度为O(n^2),是不稳定的排序

冒泡排序的时间复杂度最好情况下为O(n),最坏情况下为O(n^2),平均情况下为O(n^2),是稳定的排序

插入排序的时间复杂度最好情况下为O(n),最坏情况下为O(n^2),,平均情况下为O(n^2),是稳定的排序

1.选择排序

def selection(lista):
	leng=len(lista);
	for i in range(0,leng):
		index=i;
		min=lista[i];
		for j in range(i,leng):
			if lista[j]<min:
				index=j;
				min=lista[index];
		tmp=lista[i];
		lista[i]=lista[index];
		lista[index]=tmp;
	return lista;


2.插入排序

def insertion(lista):

	leng=len(lista);
	for i in range(1,leng):
		tmp=lista[i];
		j=i;
		while(j>0 and lista[j-1]>tmp):
			lista[j]=lista[j-1];
			j=j-1;
		lista[j]=tmp;
	return lista;

3.冒泡排序

def bubble(lista):
	leng=len(lista);
	for i in range(0,leng):
		for j in range(1,leng-i):
			if lista[j-1]>lista[j]:
				lista[j-1],lista[j]=lista[j],lista[j-1];
	return lista;

4.冒泡排序的改进

假设在某趟排序后数组已经有序,则排序完毕。

def bubble2(lista):
	leng=len(lista);
	flag=True;
	while(flag):
		flag=False;
		for i in range(0,leng):
			for j in range(1,leng-i):
				if lista[j-1]>lista[j]:
					lista[j-1],lista[j]=lista[j],lista[j-1];
					flag=True;
	return lista;

測试排序的代码:

lista=[5,3,1,4,7,9,8,2,6];
selection(lista);      #选择排序
print lista
lista=[5,3,1,4,7,9,8,2,6];
insertion(lista);      #插入排序
print lista
lista=[5,3,1,4,7,9,8,2,6];
bubble(lista);        #冒泡排序
print lista
lista=[5,3,1,4,7,9,8,2,6];
bubble2(lista);        #冒泡排序改进
print lista

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/119010.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月24日 上午8:00
下一篇 2021年11月24日 上午8:00


相关推荐

  • nginx做正向代理_反向代理和正向代理

    nginx做正向代理_反向代理和正向代理Nginx正向代理四种方式为什么需要正向代理案例配置方式第一种生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML图表FLowchart流程图导出与导入导出导入为什么需要正向代理如果我们的服务部署在公司内网环境,不能直接访问互联网服务,就需要通过可以访问互联网的代理服务器来实现访问互联网的服务。此处我们使用Nginx作为代理服务器。案例互联网上的接口:https://

    2022年8月30日
    6
  • matlab微分方程组_matlab求微分方程特解

    matlab微分方程组_matlab求微分方程特解主要内容:matlab参数识别应用,主要适用于微分方程、微分方程组参数识别、simulink模型参数识别,领域不限。1使用matlab识别微分方程参数以及微分方程组(多个微分方程)参数2使用matlab调用simulink并识别simulink模型的参数(m函数与simulink交互)内容为本人在学习过程中总结的知识,拿出来与大家分享,希望大家多多讨论。下边贴出一部分源码,其它完整内容在附件的…

    2025年9月26日
    7
  • php反射类ReflectionClass用法实例详解

    php反射类ReflectionClass用法实例详解这篇文章主要介绍了php反射类ReflectionClass用法,结合实例形式较为详细的分析了php反射类的概念、功能与具体使用方法,需要的朋友可以参考下本文实例讲述了php反射类Reflectio

    2022年7月1日
    30
  • c语言函数回调详解_c语言回调函数例子

    c语言函数回调详解_c语言回调函数例子关于静态库和动态库的使用和制作方法。http://blog.csdn.net/morixinguan/article/details/52451612今天我们要搞明白的一个概念叫回调函数。什么是回调函数?百度的权威解释如下:回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一个函数,当这个指针被用来调用其所指向的函数时,我们就说这是回调函数。回调函数不是由该函数的实…

    2025年6月27日
    2
  • 主机和qemu虚拟机互相访问_kvm虚拟机下载

    主机和qemu虚拟机互相访问_kvm虚拟机下载安装qemu/kvmyuminstallqemu-imgqemu-kvmqemu-kvm-toolsvirt-managervirt-viewervirt-v2vvirt-toplibvirtlibvirt-pythonlibvirt-clientpython-virtinstbridge-utilstunctl接下来就可以通过命令或者界面操虚拟机命令…

    2022年8月21日
    13
  • Springboot 整合RabbitMq ,用心看完这一篇就够了

    Springboot 整合RabbitMq ,用心看完这一篇就够了该篇文章内容较多,包括有rabbitMq相关的一些简单理论介绍,provider消息推送实例,consumer消息消费实例,Direct、Topic、Fanout的使用,消息回调、手动确认等。(但是关于rabbitMq的安装,就不介绍了)在安装完rabbitMq后,输入http://ip:15672/,是可以看到一个简单后台管理界面的。在这个界面里面我们可以做些什么?可以手动创建…

    2022年5月15日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号