原帖地址 http://kongec.blog.sohu.com/85141353.html

附  六分钟演示15中算法

http://www.guokr.com/post/482666/

一、插入排序(Insertion Sort)
1. 基本思想:
每次将一个待排序的数据元素,插入到前面已经排好序的数列中的适当位置,使数列依然有序;直到待排序数据元素全部插入完为止。
2. 排序过程:  
【示例】:
[初始关键字] [49] 38 65 97 76 13 27 49
J=2(38) [38 49] 65 97 76 13 27 49
J=3(65) [38 49 65] 97 76 13 27 49
J=4(97) [38 49 65 97] 76 13 27 49
J=5(76) [38 49 65 76 97] 13 27 49
J=6(13) [13 38 49 65 76 97] 27 49
J=7(27) [13 27 38 49 65 76 97] 49
J=8(49) [13 27 38 49 49 65 76 97]

  1. void sort(int *p) //添加监视哨
  2. {
  3. int b[11]={0};
  4. for(int i=0;i<10;i++)
  5. b[i+1]=p[i];
  6. int j=0;
  7. for(int i=2;i<11;++i)
  8. {
  9. b[0]=b[i];
  10. j=i-1;
  11. while(b[0]<b[j])
  12. {
  13. b[j+1]=b[j];
  14. --j;
  15. }
  16. b[j+1]=b[0];
  17. }
  18. for(int i=0;i<10;i++)
  19. p[i]=b[i+1];
  20. }
  1. void sort(int *p)//不添加监视哨
  2. {
  3. int b[10]={0};
  4. int temp=0;
  5. for(int i=1;i<10;i++)
  6. {
  7. int index=i;
  8. while(index)
  9. {
  10. if(p[index]<p[index-1])
  11. {
  12. temp=p[index];
  13. p[index]=p[index-1];
  14. p[index-1]=temp;
  15. }
  16. index--;
  17. }
  18. }
  19. }

  

  1. int _tmain(int argc, _TCHAR* argv[])
  2. {
  3. int a[10]={2,4,3,1,7,5,6,9,8,0};
  4. sort(a);
  5. for(int i=0;i<10;i++)
  6. cout<<a[i]<<endl;
  7. return 0;
  8. }

二、选择排序
1. 基本思想:
每一趟从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在已排好序的数列的最后,直到全部待排序的数据元素排完。
2. 排序过程:
【示例】:
初始关键字 [49 38 65 97 76 13 27 49]
第一趟排序后 13 [38 65 97 76 49 27 49]
第二趟排序后 13 27 [65 97 76 49 38 49]
第三趟排序后 13 27 38 [97 76 49 65 49]
第四趟排序后 13 27 38 49 [49 97 65 76]
第五趟排序后 13 27 38 49 49 [97 97 76]
第六趟排序后 13 27 38 49 49 76 [76 97]
第七趟排序后 13 27 38 49 49 76 76 [ 97]
最后排序结果 13 27 38 49 49 76 76 97

  1. void sort(int *p)
  2. {
  3. int temp=0;
  4. int temp1=0;
  5. for(int i=0;i<10;++i)
  6. {
  7. temp=p[i];
  8. for(int j=i;j<10;++j)
  9. {
  10. if(p[j]<temp)
  11. {
  12. temp1=p[j];
  13. p[j]=temp;
  14. temp=temp1;
  15.  
  16. }
  17. }
  18. p[i]=temp;
  19. }
  20. }
  21. int _tmain(int argc, _TCHAR* argv[])
  22. {
  23. int a[10]={2,4,3,1,7,5,6,9,8,0};
  24. sort(a);
  25. for(int i=0;i<10;i++)
  26. cout<<a[i]<<endl;
  27. return 0;
  28. }

三、冒泡排序(BubbleSort)
1. 基本思想:
两两比较待排序数据元素的大小,发现两个数据元素的次序相反时即进行交换,直到没有反序的数据元素为止。
2. 排序过程:
设想被排序的数组R[1..N]垂直竖立,将每个数据元素看作有重量的气泡,根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R,凡扫描到违反本原则的轻气泡,就使其向上"漂浮",如此反复进行,直至最后任何两个气泡都是轻者在上,重者在下为止。
【示例】:
49 13 13 13 13 13 13 13 
38 49 27 27 27 27 27 27
65 38 49 38 38 38 38 38
97 65 38 49 49 49 49 49
76 97 65 49 49 49 49 49
13 76 97 65 65 65 65 65
27 27 76 97 76 76 76 76
49 49 49 76 97 97 97 97

  1. void sort(int *p)
  2. {
  3. int temp=0;
  4. for(int i=0;i<10;++i)
  5. {
  6. for(int j=i+1;j<10;++j)
  7. {
  8. if(p[j]<p[i])
  9. {
  10. temp=p[j];
  11. p[j]=p[i];
  12. p[i]=temp;
  13. }
  14. }
  15. }
  16. }
  1. int _tmain(int argc, _TCHAR* argv[])
  2. {
  3. int a[10]={2,4,3,1,7,5,6,9,8,0};
  4. sort(a);
  5. for(int i=0;i<10;i++)
  6. cout<<a[i]<<endl;
  7. return 0;
  8. }

  

四、快速排序(Quick Sort)
1. 基本思想:
在当前无序区R[1..H]中任取一个数据元素作为比较的"基准"(不妨记为X),用此基准将当前无序区划分为左右两个较小的无序区:R[1..I- 1]和R[I 1..H],且左边的无序子区中数据元素均小于等于基准元素,右边的无序子区中数据元素均大于等于基准元素,而基准X则位于最终排序的位置上,即R [1..I-1]≤X.Key≤R[I 1..H](1≤I≤H),当R[1..I-1]和R[I 1..H]均非空时,分别对它们进行上述的划分过程,直至所有无序子区中的数据元素均已排序为止。
1. 排序过程:
初始关键字 [49 38 65 97 76 13 27 49]
一趟排序之后 [27 38 13] 49 [76 97 65 49] 
二趟排序之后 [13] 27 [38] 49 [49 65]76 [97]
三趟排序之后 13 27 38 49 49 [65]76 97
最后的排序结果 13 27 38 49 49 65 76 97

  1. void sort(int *a,int i,int j)
  2. {
  3. int m=i;
  4. int n=j;
  5. int k=0;
  6. int temp=0;
  7. k=a[(i+j)/2];
  8. do
  9. {
  10. while(a[m]<k&&m<j) m++;
  11. while(a[n]>k&&n>i) n--;
  12. if(m<=n)
  13. {
  14. temp=a[m];
  15. a[m]=a[n];
  16. a[n]=temp;
  17. m++;
  18. n--;
  19. }
  20. }while(m<=n);
  21. if(m<j) sort(a,m,j);
  22. if(n>i) sort(a,i,n);
  23. }
  24. int _tmain(int argc, _TCHAR* argv[])
  25. {
  26. int a[10]={2,4,3,1,7,5,6,9,8,0};
  27. sort(a,0,9);
  28. for(int i=0;i<10;i++)
  29. cout<<a[i]<<endl;
  30. return 0;
  31. }

  

C++ 排序总结的更多相关文章

  1. javascript中的Array对象 —— 数组的合并、转换、迭代、排序、堆栈

    Array 是javascript中经常用到的数据类型.javascript 的数组其他语言中数组的最大的区别是其每个数组项都可以保存任何类型的数据.本文主要讨论javascript中数组的声明.转换 ...

  2. iOS可视化动态绘制八种排序过程

    前面几篇博客都是关于排序的,在之前陆陆续续发布的博客中,我们先后介绍了冒泡排序.选择排序.插入排序.希尔排序.堆排序.归并排序以及快速排序.俗话说的好,做事儿要善始善终,本篇博客就算是对之前那几篇博客 ...

  3. JavaScript实现常用的排序算法

    ▓▓▓▓▓▓ 大致介绍 由于最近要考试复习,所以学习js的时间少了 -_-||,考试完还会继续的努力学习,这次用原生的JavaScript实现以前学习的常用的排序算法,有冒泡排序.快速排序.直接插入排 ...

  4. [C#][算法] 用菜鸟的思维学习算法 -- 马桶排序、冒泡排序和快速排序

    用菜鸟的思维学习算法 -- 马桶排序.冒泡排序和快速排序 [博主]反骨仔 [来源]http://www.cnblogs.com/liqingwen/p/4994261.html  目录 马桶排序(令人 ...

  5. 算法与数据结构(十三) 冒泡排序、插入排序、希尔排序、选择排序(Swift3.0版)

    本篇博客中的代码实现依然采用Swift3.0来实现.在前几篇博客连续的介绍了关于查找的相关内容, 大约包括线性数据结构的顺序查找.折半查找.插值查找.Fibonacci查找,还包括数结构的二叉排序树以 ...

  6. 算法与数据结构(七) AOV网的拓扑排序

    今天博客的内容依然与图有关,今天博客的主题是关于拓扑排序的.拓扑排序是基于AOV网的,关于AOV网的概念,我想引用下方这句话来介绍: AOV网:在现代化管理中,人们常用有向图来描述和分析一项工程的计划 ...

  7. 使用po模式读取豆瓣读书最受关注的书籍,取出标题、评分、评论、题材 按评分从小到大排序并输出到txt文件中

    #coding=utf-8from time import sleepimport unittestfrom selenium import webdriverfrom selenium.webdri ...

  8. javascript排序

    利用array中的sort()排序 w3cfunction sortNumber(a,b) { return a - b } var arr = new Array(6) arr[0] = " ...

  9. iOS自定义model排序

    在开发过程中,可能需要按照model的某种属性排序. 1.自定义model @interface Person : NSObject @property (nonatomic,copy) NSStri ...

  10. Lucene4.4.0 开发之排序

    排序是对于全文检索来言是一个必不可少的功能,在实际运用中,排序功能能在某些时候给我们带来很大的方便,比如在淘宝,京东等一些电商网站我们可能通过排序来快速找到价格最便宜的商品,或者通过排序来找到评论数最 ...

随机推荐

  1. 七步精通Python机器学习--转载

    作者简介: Matthew Mayo    翻译:王鹏宇 开始.这是最容易令人丧失斗志的两个字.迈出第一步通常最艰难.当可以选择的方向太多时,就更让人两腿发软了. 从哪里开始? 本文旨在通过七个步骤, ...

  2. django 常用字段类型

    <> CharField #字符串字段, 用于较短的字符串. #CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符数 ...

  3. 定义 S4 类

    S3 类仅用一个字符向量表示,与之不同的是,S4 类要求对类和方法有正式定义.为了定义一个 S4 类,我们需要调用 setClass( ),并提供一种类成员的表示,这种表示被称为字段(slots).通 ...

  4. InfiniBand 与Intel Omni-Path Architecture

    Intel Omni-Path Architecture (OPA) 是一种与InfiniBand相似的网络架构 可以用来避免以下PCI总线一些缺陷: 1.由于采用了基于总线的共享传输模式,在PCI总 ...

  5. css强制html不换行 css强制英文单词断行 重拾丢失的

    css强制html不换行 css强制英文单词断行 强制不换行 div{ white-space:nowrap; } 自动换行 div{ word-wrap: break-word; word-brea ...

  6. Hibernate批量处理数据、[HQL连接查询]

    一.批量处理操作 批量处理数据是指在一个事务场景中处理大量数据.在应用程序中难以避免进行批量操作,Hibernate提供了以下方式进行批量处理数据: (1)使用HQL进行批量操作 数据库层面 (2)使 ...

  7. bzoj1067

    题意: 给你下雨量,让你判断每一句话是否正确 题解: 线段树 用来维护判断 代码: #include <cstdio> #include <cstring> #include ...

  8. wbr 视机而动

    链接 在适当的时候, 除非能容下整个单车, 才保留一行: 缩放浏览器, 试试这段就知道了 <p>To learn AJAX, you must be familiar with the X ...

  9. VMware上安装CenterOS

    1.环境:Win10.VMware Workstation 12.Centeros 7 2.VMware workstation12安装 双击“VMware_workstation_full_12.5 ...

  10. 10055 - Hashmat the Brave Warrior & 各数据类型所占字节数 (C语言)

    Problem A Hashmat the brave warrior Input: standard input Output: standard output Hashmat is a brave ...