首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Python实现计数排序

计数排序适合数据量大且数据范围小的数据排序,如对人的年龄进行排序,对考试成绩进行排序等。 计数排序先找到待排序列表中的最大值 k,开辟一个长度为 k+1 的计数列表,计数列表中的所有初始值都为 0。...然后创建一个新列表,根据计数列表中统计的数量,依次在新列表中添加对应数量的 i ,得到排好序的列表。 二、计数排序原理 计数排序的原理如下: 1....三、Python实现计数排序 # coding=utf-8 def counting_sort(array): if len(array) < 2: return array...2, 5, 9, 5, 7, 6] print(counting_sort(array)) 运行结果: [2, 2, 3, 3, 5, 5, 5, 6, 7, 7, 7, 9] 代码中,使用Python...时间复杂度 在计数排序中,需要走访待排序列表中的每一个元素,进行计数,列表长度为 n ,然后需要遍历计数列表,添加数据到新列表中,计数列表长度为 k+1 ,时间复杂度为 T(n)=n+k+1,再乘计数和添加数据的步骤数

92450
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Python算法——计数排序

    计数排序是一种线性时间复杂度的排序算法,具有稳定性和适用性广泛的特点。本文将详细介绍计数排序的工作原理和Python实现。...计数排序的工作原理 计数排序的基本思想是: 统计数组中每个元素出现的次数,得到元素的频率统计信息。 根据频率统计信息,重建有序数组。 计数排序的关键在于如何统计元素的频率以及如何重建有序数组。...Python实现计数排序 下面是Python中的计数排序实现: def counting_sort(arr): max_val = max(arr) min_val = min(arr)...统计元素频率,注意需要将元素减去最小值以适配计数数组。 重建有序数组,根据计数数组信息构建有序数组。...示例代码 下面是一个使用Python进行计数排序的示例代码: def counting_sort(arr): max_val = max(arr) min_val = min(arr)

    30510

    Python数组切片_python print数组

    文章目录 关于索引 一维数组(冒号:) 1、一个参数:a[i] 2、两个参数:b=a[i:j] 3、三个参数:格式b = a[i:j:s] 4、一个例子 二维数组(逗号,) 取元素...,是 python 最通用的复合数据类型。 关于索引 从左到右索引默认 0 开始,从右到左索引默认 -1 开始。...类似的,X[n0,n1,n2]表示取三维数组,取N维数组则有N个参数,N-1个逗号分隔。...21,22]]; 切片特殊情况 X[:e0,s1:] 特殊情况,即左边从0开始可以省略X[:e0,s1:e1],右边到结尾可以省略X[s0:,s1:e1],取某一维全部元素X[:,s1:e1],事实上和Python...blog.csdn.net/Arry_Lee/article/details/83108442 推荐博客:https://blog.csdn.net/qq_41375609/article/details/95027651 python

    2.4K10

    内存中的Python:Python引用计数指南

    变量是内存引用 Python中的变量是内存引用。如果输入x = [1,2]时会发生什么?[1,2]是对象。 回想一下,一切都是Python中的对象。[1,2]将在内存中创建。...引用计数 现在已经在内存中创建了一个list对象,而且x对该对象进行了引用。那么y=[1,2]和y=x有什么区别? 当输入y=[1,2]时,它将在内存中创建一个新的list对象,并且y将引用它。...[1, 2] print(hex(id(x))) # output: 0x101bea8 print(hex(id(y))) # output: 0x31a5528 而当输入y=x时,等同于告诉Python...引用计数的数目 接下来的问题是,有多少变量引用同一个对象? 错误的用法: 我看到有些人在使用sys.getrefcount(var)时不知道如何传递var,而是向对象添加引用。一起看看下面的例子。

    1.4K20

    计数排序与桶排序python实现

    计数排序与桶排序python实现 计数排序 计数排序原理: 找到给定序列的最小值与最大值 创建一个长度为最大值-最小值+1的数组,初始化都为0 然后遍历原序列,并为数组中索引为当前值-最小值的值...+1 此时数组中已经记录好每个值的数量,自然也就是有序的了 例如: ?...计数排序实现 下面为列表的计数排序 def count_sort(s): """计数排序""" # 找到最大最小值 min_num = min(s) max_num =...当数值中有非整数时,计数数组的索引无法分配 桶排序 桶排序原理: 桶排序与计数排序类似,但可以解决非整数的排序 桶排序相当于把计数数组划分为按顺序的几个部分 每一部分叫做一个桶,它来存放处于该范围内的数...然后再对每个桶内部进行排序,可以使用其他排序方法如快速排序 最后整个桶数组就是排列好的数据,再将其返回给原序列 举例: ?

    1.1K10
    领券