Python数据结构与算法——排序(希尔、计数、桶、基数排序)

目录

希尔排序

计数排序

桶排序

基数排序


希尔排序

希尔排序是一种分组插入排序算法

步骤:

首先取一个整数d1 = n/2,将元素分为d1个组,每组相邻量元素之间距离为d1,在各组内进行直接插入排序;

取第二个整数d2 = d1/2,重复上述分组排序过程,直到di = 1,即所有元素在同一组内进行直接插入排序。

希尔排序每趟并不使某些元素有序,而是使整体数据越来越接近有序;最后一趟排序使所有数据有序。

希尔排序根据gap选择时间复杂度不同

from cal_time import *# 插入排序修改
def insert_sort_gap(li, gap):for i in range(gap, len(li)):tmp = li[i]j = i - gapwhile j >= 0 and li[j] > tmp:li[j+gap] = li[j]j -= gapli[j+gap] = tmp# 希尔排序
@cal_time
def shell_sort(li):d = len(li) // 2while d >= 1:insert_sort_gap(li, d)d = d // 2li = list(range(100000))
import random
random.shuffle(li)
shell_sort(li)

计数排序

对列表进行排序,已知列表中的数范围都在0-100之间,设计时间复杂度为O(n)的算法。

import random
from cal_time import *@cal_time
def count_sort(li, max_count = 100):count = [0 for _ in range(max_count + 1)]for val in li:count[val] += 1li.clear()for ind, val in enumerate(count):for i in range(val):li.append(ind)return lili = [random.randint(0, 100) for i in range(100000)]
count_sort(li)

桶排序

在计数排序中会出现这么一个问题:

有这样一串数字1,2,1000000,5,3,2...

其中最大数字为1000000,难道要开辟1000000大的空间来进行排序吗?

很显然浪费空间

桶排序就是计数排序的改造(使用不是很多)

桶排序:首先将元素分在不同的桶中,再对每个桶中的元素排序。

也可以边放边排序,在往桶里丢的过程中使用排序使桶内的元素有序。

桶排序的表现取决于数据的分布,也就是需要对不同数据排序时采取不同的分桶策略

平均情况时间复杂度:O(n+k)

最坏情况时间复杂度:O(n2k)

空间复杂度:O(nk)

import random
from cal_time import *@cal_time
def bucket_sort(li, n = 100, max_num = 10000): # n表示桶的个数,max_num表示数的范围buckets = [[] for _ in range(100)] # 创建二维列表,列表内每一个列表是一个桶for var in li:# 现在有10000个数,100个桶,所以每个桶放100个数# i表示var放到几号桶里i = min(var // (max_num // n), n-1) # min表示如果数大于等于10000时,将这些数放到最后一个桶里buckets[i].append(var)  # 把var加到桶内# 保持桶内顺序for j in range(len(buckets[i]) - 1, 0, -1):if buckets[i][j] < buckets[i][j-1]:buckets[i][j], buckets[i][j-1] = buckets[i][j-1], buckets[i][j]else: breaksorted_li = []for buc in buckets:sorted_li.extend(buc)return sorted_lili = [random.randint(0, 10000) for i in range(100000)]
li = bucket_sort(li)

基数排序

多关键字排序:

假如现在有一个员工表,要求按照薪资排序,年龄相同的员工按照年龄排序

先按照年龄进行排序,再按照薪资进行稳定排序

对数字排序也可以看作多关键字排序

先根据个位分桶,再根据十位分桶...

时间复杂度:O(kn)

空间复杂度:O(k+n)

import random
from cal_time import *@cal_time
def radix_sort(li):max_num = max(li)  # 循环次数根据最大值确定 9 -> 1 ; 99 -> 2 ; 888 -> 3 ; 10000 -> 5it = 0while 10**it <= max_num:  # 做循环buckets = [[] for _ in range(10)]for var in li:digit = (var // (10**it)) % 10buckets[digit].append(var)# 分桶完成li.clear()for buc in buckets:li.extend(buc)# 把数重新写回liit += 1li = list(range(100000))
random.shuffle(li)
radix_sort(li)

代码自己手动敲一遍理解更深哦!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/778212.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入浅出的揭秘游标尺模式与迭代器模式的神秘面纱 ✨

​&#x1f308; 个人主页&#xff1a;danci_ &#x1f525; 系列专栏&#xff1a;《设计模式》 &#x1f4aa;&#x1f3fb; 制定明确可量化的目标&#xff0c;坚持默默的做事。 &#x1f680; 转载自&#xff1a;设计模式深度解析&#xff1a;深入浅出的揭秘游标尺模式与迭代…

24计算机考研调剂 | 大连海洋大学

大连海洋大学 AET水产设施养殖中心课题组招生 考研调剂招生信息 年级:2024 招生人数:20 招生状态:正在招生中 招生专业&#xff1a; 理学->海洋科学->海洋生物学 农学->水产->水产养殖 工学->机械工程、计算机科学 农学->农业资…

【测试开发学习历程】Python数据类型:字符串-str(上)

目录 1 Python中的引号 2 字符串的声明 3 字符串的切片 4 字符串的常用函数 4.1 len()函数 4.2 ord()函数 4.3 chr()函数 5 字符串的常用方法&#xff08;内置方法/内建方法&#xff09; 5.1 find()方法 5.2 index()方法 5.3 rfind()方法 5.4 rindex()方法 1 Python…

SAP-CO主数据之统计指标创建-<KK01>

公告&#xff1a;周一至周五每日一更&#xff0c;周六日存稿&#xff0c;请您点“关注”和“在看”&#xff0c;后续推送的时候不至于看不到每日更新内容&#xff0c;感谢。 目录 一、背景&#xff1a; 成本中心主数据创建&#xff1a;传送门 成本要素主数据创建&#xff1…

Linux内核之最核心数据结构之二:struct inode(三十一)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

图腾柱PFC:HP1010为您的电动两轮车之旅提供绿色,高效,安全的动力

电动两轮车不仅为当今生活提供了便利&#xff0c;更是一种健康和绿色的出行方式。想象一下&#xff0c;在经过一整晚的充分休息&#xff0c;骑上爱车&#xff0c;满血复活的准备开始新的一天。您会愿意带着如何给心爱的两轮车充电的担心开始这一天吗&#xff1f; 随着越来越…

MySQL---触发器

一、介绍 触发器是与表有关的数据库对象&#xff0c;指在insert/update/delete之前(BEFORE)或之后(AFTER)&#xff0c;触发并执行触发器中定义的SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性, 日志记录 , 数据校验等操作 。 使用别名OLD和NEW来引用触…

CorelDRAW25.0.0.230中文最新开心和谐版本

CorelDRAW是一款非常流行的矢量图形设计软件&#xff0c;其25.0.0.230版本带来了许多新特性和更新内容。以下是我所能提供的相关信息&#xff1a; 首先&#xff0c;关于特性方面&#xff0c;CorelDRAW 25.0.0.230版本具有强大的矢量编辑功能&#xff0c;用户可以轻松创建和编辑…

Leetcode53 最大子数组和(进阶版)

题目&#xff1a;给你一个整数数组 nums&#xff0c;请你找出一个具有最大和的连续子数组(子数组最少包含一个元素)&#xff0c;返回其最大和&#xff0c;并输出开始索引与结束索引 注意&#xff1a;子数组是数组中的一个连续部分 示例1&#xff1a; 输入&#xff1a;nums[-2,…

DSVPN实验报告

一、分析要求 1. 配置R5为ISP&#xff0c;只能进行IP地址配置&#xff0c;所有地址均配为公有IP地址。 - 在R5上&#xff0c;将接口配置为公有IP地址&#xff0c;并确保只进行了IP地址配置。 2. R1和R5之间使用PPP的PAP认证&#xff0c;R5为主认证方&#xff1b;R2于R5之间…

6-74 根据二叉树的后序遍历序列和中序遍历序列,用括号表示法输出二叉树。 (Java语言描述)

根据二叉树的后序遍历序列和中序遍历序列,用括号表示法输出二叉树。 请将其中的创建方法补充完整。 函数接口定义: private BTNode CreateBT21(String post,int i, String in,int j,int n){ }private void toString1(BTNode root) { } 裁判测试程序样例: import java.uti…

ES6 学习(三)-- es特性

文章目录 1. Symbol1.1 使用Symbol 作为对象属性名1.2 使用Symbol 作为常量 2. Iterator 迭代器2.1 for...of循环2.2 原生默认具备Interator 接口的对象2.3 给对象添加Iterator 迭代器2.4 ... 解构赋值 3. Set 结构3.1 初识 Set3.2 Set 实例属性和方法3.3 遍历3.4 相关面试题 4…

a = 3中的3在栈中还是堆中?

1、栈区&#xff08;stack&#xff09; 由编译器自动分配释放&#xff0c;存放函数的参数值&#xff0c;局部变量的值等。 2、堆区&#xff08;heap&#xff09; 是一个可动态申请的内存空间&#xff08;其记录空闲内存空间的链表由操作系统维护&#xff09;&#xff0c;在j…

基于js css的瀑布流demo

要实现照片按照瀑布流展示&#xff0c;写个小demo&#xff0c;记录下。 瀑布流实现思路如下&#xff1a; CSS 弹性布局对 3 列按横向排列&#xff0c;对每一列内部按纵向排列 html代码&#xff1a; <div class"content"></div> css代码&#xff1a; …

基于SSM学生信息管理系统

采用技术 基于SSM学生信息管理系统的设计与实现~ 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SpringMVCMyBatis 工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 页面展示效果 总体功能设计 登录页面 后台首页 学生信息页面 添加学生用户 编辑…

go | channel direction、channel sync、channelbuffer

go 中的管道通信 管道通信直连&#xff0c;管道的特点就是单工&#xff0c;一方只能接受/发送 package main import ("fmt" )func ping(pings chan<- string, msg string){pings <- msg }/*函数pong中 参数pings 是一个接收通道&#xff08;只能从管道接收数据…

第三十六章 管理和监控Web网关

文章目录 第三十六章 管理和监控Web网关检查系统状态IRIS的连接 IRIS 服务器表应用程序路径表 第三十六章 管理和监控Web网关 本页介绍如何通过Web网关管理页面管理和监控系统间Web网关。 检查系统状态 系统状态选项显示所有活动连接的状态。必须是系统管理员才能使用此功能…

动态规划刷题(算法竞赛、蓝桥杯)--导弹拦截(线性DP)

1、题目链接&#xff1a;[NOIP1999 提高组] 导弹拦截 - 洛谷 #include <bits/stdc.h> using namespace std; const int N2e55; int a[N],x,n; int b[N],len;int main(){while(cin>>x)a[n]x;//求最长不上升子序列 b[0]2e9;//初始化为无穷大for(int i1;i<n;i){if(…

C++(9): std::stack的使用

std::stack 是 C 标准模板库&#xff08;STL&#xff09;中的一个容器适配器&#xff0c;它提供了后进先出&#xff08;LIFO&#xff09;的数据结构。作为适配器&#xff0c;std::stack 基于其他容器&#xff08;默认是 std::deque&#xff0c;但也可以指定为 std::vector&…

计算机专业在找工作时的注意事项

目录 说在前面关于我一些忠告关于简历关于银行写在最后 说在前面 满满的求生欲。我不是什么大佬&#xff0c;更没有能力教大家什么。只是看到有不少学弟学妹&#xff0c;还在为找一份工作焦头烂额&#xff0c;却没有努力的方向。所以这里斗胆给计算机相关专业的学弟学妹们的一…