面试必考题目+各种排序实例及点评
1.按平均时间将排序分为4类;
A.平方阶O(n^2)排序:一般为简单的排序,例如直接插入、直接选择和冒泡排序;
B.线性对数阶O(nlgn)排序:如快速、堆和归并排序;
C.O(n^m)阶排序:m位于0和1之间的常数,即0 A.若n较小时(n<50),可采用直接插入或直接选择排序。 当记录规模较小时,直接插入排序较好。否则因为直接选择移动的记录数少于直接插入,应直接选择选择排序为宜。 B.若文件的初始状态基本有序(指正序),则应选择直接插入排序,冒泡排序或随机的快速排序为宜。 C.若n较大时,应采用时间复杂度为O(nlgn)的排序方法:快速排序、堆排序或归并排序。 快速排序被认为是目前基于比较的内部排序中最好的方法。当待排序的关键字随机分布时,快速排序的平均时间最短。 堆排序所需的辅助空间少于快速排序,并且不会出现快速排序可能出现的最坏情况。这两种排序都是不稳定的。 若要求排序稳定,则可选用归并排序。 shell排序:分组的直接插入排序,在n比较大的时候较直接插入排序有较大的改进,它是不稳定的。最好的时间复杂度是O(n),最坏的是O(n^2)。 3.插入排序、冒泡排序、归并排序是稳定的,选择排序、希尔排序、快速排序、堆排序时不稳定的 4.各种排序算法如下: a. shell排序:分组的直接插入排序,在n比较大的时候较直接插入排序有较大的改进,它是不稳定的。最好的时间复杂度是O(n),最坏的是O(n^2)。 #include void shell_sort(int a[],int len) { int h,i,j,temp; for(h=len/2;h>0;h=h/2) { for (i=h;i void print_array(int a[],int len) { for (int i=0;i b.直接插入排序: #include void insert_sort(int a[],int len) { int i,j,temp; for (i=1;i } void print_array(int a[],int len) { for (int i=0;i c.交换排序中的冒泡排序:是就地排序,且是稳定的,由于他的记录移动次数较多,故平均时间性能比直接插入排序要差的多,最好的时间复杂度是O(n),最差是O(n^2),平均时间复杂度是O(n^2) #include void bubble_sort(int a[],int len) { int i,j,temp; for (i=0;i void print_array(int a[],int len) { for (int i=0;i } cout< void main() { int a[]={7,3,5,8,9,1,2,4,6}; cout<<\ print_array(a,9); bubble_sort(a,9); cout<<\ print_array(a,9); } d.交换排序中的quick_sort 是一种不稳定的排序方法,平均时间复杂度是O(n*lgn/lg2) 最差情况时间复杂度是O(n^2) #include void quick_sort(int a[],int low,int high) { int i,j,pivot; if(low void print_array(int a[],int len) { for (int i=0;i } cout< void main() { int a[]={54,38,96,23,15,72,60,45,83}; cout<<\ print_array(a,9); quick_sort(a,0,8); cout<<\ print_array(a,9); } e.直接选择排序: #include void select_sort(int a[],int len) { int i,j,x,l; for (i=0;i void print_array(int a[],int len) { for (int i=0;i
相关推荐:
- [学前教育]MC9S12XS256RMV1 xs128芯片手册4
- [学前教育]安东尼语录经典语录
- [学前教育]e级gps控制测量技术设计书
- [学前教育]苏教版2022-2022学年八年级下学期期末
- [学前教育]装修公司推广 营销
- [学前教育]家政服务合同(完整版)
- [学前教育]湖北省2016届高三联考语文试题
- [学前教育]爱立信无涯学习系统LTE题库1-LTE基础知
- [学前教育]揭秘大众柴油车作弊软件原理
- [学前教育]人才流失原因及对策分析
- [学前教育]房屋建筑施工工程劳务分包合同
- [学前教育]国际贸易实务试卷A卷09.6
- [学前教育]校园废品回收活动计划方案书范文格
- [学前教育]电大成本会计试题及答案
- [学前教育]大学物理实验 华南理工出版社 绪论答案
- [学前教育]爱丁堡产后抑郁量表
- [学前教育]液压冲击的危害、产生原因与防止方法(
- [学前教育]学生工作总结高一学生期中考试总结_020
- [学前教育]人民医院医疗废物管理规章制度大全
- [学前教育]阳光维生素的巨大抗癌潜能阅读题答案.d
- 马云在云锋基金江苏论坛闭幕式的发言
- 试论小学体育教育中的心理健康教育-教
- 语文A版一年级下册《语文乐园一》教学
- 2021四川大学物理化学考研真题经验参考
- [人教A版]2015-2016学年高中数学 第二
- 终端网点销售返利协议书
- 江苏省2015年眼科学主治医师青光眼考试
- 2017年部编人教版八年级语文上册教案
- 十一中学七年级英语上册Unit7Howmuchar
- 以赛促教的创新性实验教学机制建设实践
- 平凉市崆峒区2015七年级下生物期末试题
- 琶洲(地块五)A、B塔楼1、2#塔吊基础
- 一级医院工作制度与人员岗位职责
- 2018北京西城区高三二模理科数学试题及
- 炒股密码线技术 - 图文
- 职高学生生涯发展辅导教案
- 语文人教版四年级上册8 世界地图引出的
- 最新最新人教版二年级上册全册数学教案
- 2017高考英语全国2卷精彩试题(有问题
- 普通心理学笔记




