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

计数排序(Counting Sort

文章目录 算法描述 动图演示 代码实现 算法分析 计数排序的核心在于将输入的数据值转化为键存储在额外开辟的数组空间中。 作为一种线性时间复杂度的排序,计数排序要求输入的数据必须是有确定范围的整数。...计数排序(Counting sort)是一种稳定的排序算法。计数排序使用一个额外的数组C,其中第i个元素是待排序数组A中值等于i的元素的个数。然后根据数组C来将A中的元素排到正确的位置。...算法描述 找出待排序的数组中最大和最小的元素; 统计数组中每个值为i的元素出现的次数,存入数组C的第i项; 对所有的计数累加(从C中的第一个元素开始,每一项和前一项相加); 反向填充目标数组:将每个元素...计数排序不是比较排序,排序的速度快于任何比较排序算法。...由于用来计数的数组C的长度取决于待排序数组中数据的范围(等于待排序数组的最大值与最小值的差加上1),这使得计数排序对于数据范围很大的数组,需要大量时间和内存。

53620

计数排序(Counting Sort)详解

计数排序(Counting Sort)是一种非比较排序算法,其核心思想是通过计数每个元素的出现次数来进行排序,适用于整数或有限范围内的非负整数排序。这个算法的特点是速度快且稳定,适用于某些特定场景。...countingSort.jpg 算法原理 计数排序的基本思想是: 计数:遍历待排序的数组,统计每个元素出现的次数,并将统计结果存储在一个计数数组中。...计数数组的索引对应着元素的值,而计数数组中的值表示该元素出现的次数。 累积计数:对计数数组进行累积计数,即将每个元素的计数值加上前一个元素的计数值,得到每个元素在排序后数组中的位置。...第一次遍历待排序数组,统计每个元素出现的次数,将结果存储在计数数组中。 对计数数组进行累积计数,确保计数数组中的每个元素表示小于等于该元素值的元素个数。...空间复杂度:O(n + k),需要额外的计数数组和结果数组。 稳定性:计数排序是一种稳定的排序算法,不改变相同元素的相对顺序。

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

Linux 命令 | sort

Linux 命令 sort 命令解析 sort 命令用于对文本文件进行排序,可以将文件中每行作为一个记录,按照一定的规则进行排序,默认情况下以 ASCII 码为比较方式进行排序。...sort 的一般形式如下: sort [-fbMnrtuk] [file] -f 忽略字符大小写; -b 忽略行首空格字符; -M 按月份排序; -n 以数值大小排序; -r 以相反顺序排序; -t...Linux 命令 sort 命令注意事项 sort 命令对原文件排序,不会新建文件。 sort 可以使用管道符连续多个排序操作。 sort 按行排序,每行为一个记录。...sort 按照 ASCII 码排序,可以使用 -n 参数进行数值排序。 sort 可以指定分隔符进行排序,使用 -t 参数。 sort 可以指定排序的列数和类型,使用 -k 参数。...sort 可以去除重复行,使用 -u 参数。

17410

Linuxsort 命令

简介 sort 是用来排序的,Unix Shell 的传统是对问本行做处理,因此 sort 也是对文本行进行排序,如果需要排序字段,则可以通过指定 -k,-t 等选项来实现。...用法 sort [options]... [file]......OPTS 指定字段排序形式,可覆盖外面的排序选项(r,n) 例子 字母序排序文件 sort data 将排序结果保存到单独文件中 sort data > output 或 sort -o output...OPTS, sort -k 3.3r data 也可以指定比较的 key 的范围, 上面例子中我们只想比较第三个到第五个字母 sort -k 3.3,3.5 data, 也可以跨字段 sort -k 2.2,3.3...与 sort data | uniq 在整行时行为是一致的,不过如果我们使用了 -k 排序字段时, 两者的行为就不一致了, sort 的 -u 比较的是排序的key。

2.3K10

Linux Shell工具篇 - 文本排序工具sort

介绍 sort命令在Linux里非常有用,它将文本文件内容进行排序,并将排序结果标准输出或重定向输出到指定文件。...数字升序去重 先按照“空格分割,然后按照第2列数字升序排序,最后对所有列去重: 1 sort -t " " -k2n,2 -uk1,2 sort.txt 运行效果 注意: 先排序再去重 3.数字升序去重结果保存到文件...1 sort -t " " -k2n,2 -uk1,2 -o sort2.txt sort.txt 运行效果 4.数字降序去重 先按照空格分割, 然后按照第2列数字降序排序,最后对所有列去重:...1 sort -t " " -k2nr,2 -uk1,2 sort.txt 运行效果 5.多列排序 数据文件准备:sort3.txt 12345678910111213 公司A,部门A,3公司A,部门...-t "," -k1,1 -k3nr,3 sort3.txt 运行效果

2.1K40

Linux文本处理命令sort详解

sort 对文本文件内容进行排序 用法:sort +选项 +文件名(可跟多个文件) 示例1:cat 1.txt ? sort 1.txt #文字,默认按字母a-z排序 ?...sort 2.txt #数字,默认按1-9排序 ? -n 参数:sort -n 2.txt #加-n,把数字从小到大排序 ?...-r 参数:sort -n -r 2.txt #-r ,倒序排序(也适用于文字) ? ? 如果一个文本有两列内容,默认按第一列排序,示例:cat 3.txt ?...sort 3.txt #默认按第一列排序 ? -t 参数:指定分隔符 -k参数:指定进行排序的列 示例:sort -t ‘,’ -k2 3.txt #以逗号’,’为分隔符,对第二列排序 ?...同样的:sort -t ‘,’ -k2n 3.txt #按第二列数字从小到大排序 ? sort -t ‘,’ -k2nr 3.txt #按第二列数字从大到小排序 ?

1.7K20

《快学BigData》--Linux sort 命令详解(10)

Linux sort 命令详解 -f :忽略大小写的差异,例如 A 与 a 视为编码相同; -b :忽略最前面的空格符部分; -M :以月份的名字来排序,例如 JAN, DEC 等等的排序方法;...source.log google:110:5000 baidu:100:5000 guge:50:3000 sohu:100:4500 A)、对数据进行正序排序 [root@hadoop1 /]# sort...100:5000 google:110:5000 guge:50:3000 sohu:100:4500 默认的是按照第一个单词进行排序 B)、对数据进行倒叙排序 [root@hadoop1 /]# sort...-r source.log sohu:100:4500 guge:50:3000 google:110:5000 baidu:100:5000 C)、对数据去重 [root@hadoop1 /]# sort...k 2 -k 3r source.log guge:50:3000 baidu:100:5000 sohu:100:4500 google:110:5000 -k 3r :表示降序排序 或者这样写 sort

71110
领券