CSP初赛知识点讲解(九)

CSP初赛知识点讲解(九)

排序

排序的时间复杂度

排序有很多种,效率也各不相同。

N 2 N^2 N2:插入排序,冒泡排序,选择排序

N l o g N Nlog_N NlogN:归并排序,堆排,快速排序,希尔排序

对于 N l o g N Nlog_N NlogN的排序,有的效率是比较稳定的,即无论什 么情况都趋近于NlogN,比如归并排序,堆排,也有一 些排序时间复杂度是不稳定的,即在最坏情况下会趋近于 n 2 n^2 n2,比如快速排序,希尔排序

排序的稳定性

排序也分为稳定排序和不稳定排序,这个稳定与否不是 指排序效率的,而是指排序前后两个相等的数相对位置 一定不发生改变,则算法稳定。

冒泡排序:稳定排序,比较相邻两个元素大小,不满足 大小关系就交换。

选择排序:不稳定排序。比如5 8 5 2 9,第一轮比较 之后2和5交换位置,相对位置就变化了。

插入排序:稳定排序,参考一张一张砌牌。

快速排序:不稳定排序,很容易想到,比如5 2 2 7 7, 第一个2和第二个7交换,第二个2和第一个7交换,位置变了。

归并排序:稳定排序,很明显,因为为递归,是一段一段的排,一定是稳定的

希尔排序:虽然是插入排序的升级版,但是他是不稳定的排序。要学的自己查资料

基数排序:后缀排序的时候讲过,很明显是稳定的

堆排:不稳定排序,这种直接交换的多半是不稳定的

时间复杂度

例题模拟:若某算法的计算时间的递推关系式为 T ( N ) = 2 T ( N ÷ 2 ) + N l o g N T(N)=2T(N\div2)+Nlog_N T(N)=2T(N÷2)+NlogN

T ( 1 ) = 1 T(1)=1 T(1)=1

则该算法的时间复杂度为()

A.O(N) B.O(NlogN) C.O(Nlog2N) D.O(N^2)

求时间复杂度的题在初赛中也是常考内容,不过都有 点不好算,但是一般还是可以猜一个大概,比如这道题,很容易才出有一个log,但是B,C中到低选哪一个 呢?直接不好求,那就先算出T(1),T(2),T(3)。。。 然后再看和哪个时间复杂度趋近。

相关推荐
青椒大仙KI113 分钟前
24/9/19 算法笔记 kaggle BankChurn数据分类
笔记·算法·分类
^^为欢几何^^6 分钟前
lodash中_.difference如何过滤数组
javascript·数据结构·算法
豆浩宇7 分钟前
Halcon OCR检测 免训练版
c++·人工智能·opencv·算法·计算机视觉·ocr
浅念同学22 分钟前
算法.图论-并查集上
java·算法·图论
何不遗憾呢31 分钟前
每日刷题(算法)
算法
立志成为coding大牛的菜鸟.35 分钟前
力扣1143-最长公共子序列(Java详细题解)
java·算法·leetcode
鱼跃鹰飞36 分钟前
Leetcode面试经典150题-130.被围绕的区域
java·算法·leetcode·面试·职场和发展·深度优先
liangbm342 分钟前
数学建模笔记——动态规划
笔记·python·算法·数学建模·动态规划·背包问题·优化问题
潮汐退涨月冷风霜1 小时前
机器学习之非监督学习(四)K-means 聚类算法
学习·算法·机器学习
B站计算机毕业设计超人1 小时前
计算机毕业设计Python+Flask微博情感分析 微博舆情预测 微博爬虫 微博大数据 舆情分析系统 大数据毕业设计 NLP文本分类 机器学习 深度学习 AI
爬虫·python·深度学习·算法·机器学习·自然语言处理·数据可视化