当前位置: 首页 > news >正文

招标网站建设方案/网站推广应该怎么做?

招标网站建设方案,网站推广应该怎么做?,重庆网站建设公司哪个最好,从零开始学做网站cdsn参考博客:常用排序算法总结(二) 计数排序 counting sort 1.计数排序是一种非常快捷的稳定性强的排序方法,时间复杂度O(nk),其中n为要排序的数的个数,k为要排序的数的组大值。计数排序对一定量的整数排序时候的速度非常快,一般快于…

参考博客:常用排序算法总结(二)

计数排序 counting sort

  1.计数排序是一种非常快捷的稳定性强的排序方法,时间复杂度O(n+k),其中n为要排序的数的个数,k为要排序的数的组大值。计数排序对一定量的整数排序时候的速度非常快,一般快于其他排序算法。但计数排序局限性比较大,只限于对整数进行排序。计数排序是消耗空间发杂度来获取快捷的排序方法,其空间发展度为O(K)同理K为要排序的最大值。

  2.计数排序的基本思想为一组数在排序之前先统计这组数中其他数小于这个数的个数,则可以确定这个数的位置。例如要排序的数为 7 4 2 1 5 3 1 5;则比7小的有7个数,所有7应该在排序好的数列的第八位,同理3在第四位,对于重复的数字,1在1位和2位(暂且认为第一个1比第二个1小),5和1一样位于6位和7位。

计数排序非常基础,他的主要目的是对整数排序并且会比普通的排序算法性能更好。例如,输入{1, 3, 5, 2, 1, 4}给计数排序,会输出{1, 1, 2, 3, 4, 5}。这个算法由以下步骤组成:

  初始化一个计数数组,大小是输入数组中的最大的数。
  遍历输入数组,遇到一个数就在计数数组对应的位置上加一。例如:遇到5,就将计数数组第五个位置的数加一。
  把计数数组直接覆盖到输出数组(节约空间)。

时间复杂度:O(n)

统计一个列表内每个元素出现的个数。用于小规模范围内计算!

弊端:

  有限定!为排序需要新建一个列表,开辟一块内存空间,而且这个空间的大小取决于排序列表的最大值。

  如果一个要排序的列表中仅有,【1,10000】这两个数,那么我们统计的话,创建的用于计数的列表就要开一一个可以存放10000个数的内存空间。这样导致的结果就是,其他的数无用并且损耗性能,时间复杂度没变但是空间复杂度增加了!这也间接的暴露了范围取值的弊端。

算法实现:

def count_sort(li, maxnum=100):"""新建一个列表,往列表内写值:param li::param maxnum::return:"""count = [0 for i in range(maxnum+1)]  #创建用以计数的所有元素都是0的列表,result = []for i in li: #遍历要计数的列表,每个元素对应的索引位置的数加1count[i] += 1for num, count in enumerate(count): #对已经完成计数的列表进行枚举打印,格式(数字,次数)for i in range(count): #再通过次数创建一个循环,出现多少次就把对应的数写入列表多少次result.append(num)def count_sorts(li, max_num):"""仅在当前列表下操作,按照次数重写列表:param li::param max_num::return:"""count = [0 for i in range(max_num + 1)]for num in li:count[num] += 1i = 0for num,m in enumerate(count):for j in range(m):li[i] = numi += 1return lili = [3,4,1,2,5,6,6,5,4,3,3]
print(count_sorts(li,max(li)))

应用:

  有一个数组[3,4,1,2,5,6,6,5,4,3,3]请写一个函数,找出该数组中没有重复的数的总和(上面的没有重复数的总和为 1+2=3)。

def count_sorts(li, max_num):"""计数排序引申,求和:param li: 传入的列表:param max_num:列表中最大值:return:和 sums"""counts = [0 for i in range(max_num + 1)]for num in li:counts[num] += 1sums = 0for num,count in enumerate(counts):# print(num,count) #打印列表内对应数字出现的次数if count == 1:sums += numreturn sumsli = [3,4,1,2,5,6,6,5,4,3,3]
print(count_sorts(li,max(li)))

 

转载于:https://www.cnblogs.com/zh605929205/p/7472093.html

http://www.lbrq.cn/news/1061209.html

相关文章:

  • 做网站中显示链接中内容/宁波seo网站排名优化公司
  • 天津 企业网站建设/品牌推广策略包括哪些内容
  • 织梦网做网站/如何在百度发布文章
  • 企业网站建设合同书.doc/武汉网站建设推广公司
  • 济南教育加盟网站建设/外链交换平台
  • dw怎么用divcss做网站/网站建设优化推广
  • 政府网站建设重要性/全免费建立自己的网站
  • dw网页制作步骤视频/seo 优化是什么
  • 网站建设大概多少费用/web设计一个简单网页
  • 个人备案网站可以做商城吗/磁力天堂
  • 重庆网站建设的好处/友情链接分析
  • web开发框架有哪些/seo要点
  • 中小企业解决方案/生哥seo博客
  • 书店如何做网站/系统优化软件推荐
  • 旅游景点网站模板/软件开发工程师
  • 怎样用阿里云服务器做网站/无代码免费web开发平台
  • 第三方微信网站建设/百度长尾关键词挖掘
  • asp.net动态网站开发技术/社群营销的十大案例
  • 做网站外包创业/百度客户端电脑版
  • 怎样做网站备份/网店推广有哪些
  • 深圳快速网站制/上海百度竞价托管
  • 深圳宝安做网站的公司/百度推广客户端怎样注册
  • 新产品开发的流程/seo网站优化培训
  • 企业网站建设方案服务/b2b平台免费推广网站
  • 电商网站建设教案/整合营销方案
  • 莆田网站建设电话/谷歌优化培训
  • 购物网站创建/企业网站的功能
  • 南通企业网站怎么建设/武汉百度快照优化排名
  • flask网站开发视频/seo 是什么
  • 盐城网站建设代理商/浙江搜索引擎优化
  • NLP自然语言处理 02 RNN及其变体
  • 2025-08-05Gitee + PicGo + Typora搭建免费图床
  • [GESP202306 四级] 2023年6月GESP C++四级上机题超详细题解,附带讲解视频!
  • 前后端交流
  • 8.3 滑窗 |栈|阶乘判断
  • ClickHouse Windows迁移方案与测试