一、引言

  对于各种排序算法也算是有了一定的了解,所以这里做一个总结。

二、冒泡排序法。

这是比较经典的排序算法,主要是通过内外两层的循环比较,使得乱序变为顺序。

  下面是一个测试代码

 #include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<int> L();
for(int i=;i<L.size();i++)
{
L[i] = - i;
}
int temp = ;
for (int i = ; i < L.size(); i++)
for (int j = L.size()-; j >= (i+); j--)
{
if (L[j-] > L[j ])
{
temp = L[j];
L[j] = L[j - ];
L[j - ] = temp;
}
}
for (int j = ; j < L.size(); j++)
{
cout << "the number is " << L[j] << endl;
}
}

  初始化为10-1,最后冒泡排序法的的结果为升序排列。

  下面是算法的运行过程。

  在第一次循环里面(即i=0的时候):

  每一次比较之后数据变化如下:

  

随着 i 的增大,蓝色区域扩展如下:

  

  最后达到有序状态。

  从上面的分析可以看出来:

  其时间复杂度:O(n 2) (这里的时间,主要花费在了比较运算上面,所以计算的是循环里面的比较次数)

  空间复杂度: O(n)  (即所有的变量占用的空间)

  算法稳定性上来说,属于稳定算法(即两个相同的元素经过排序之后的 先后顺序不变)。

二直接插入排序

  插入排序的算法思想是,将待排序的数据看做两个部分,一部分是有序数据A,一部分是无序数据B, 最开始的时候A的规模是0, B是整个的待排序数据。

  之后对于B中的每一个数据,按照顺序插入到A中,直至整个过程完成。

  例如,对于一个待排序数组来说,过程如下:

  

#include <iostream>
using namespace std;
void Sorted(int* x, int length);
int main(void)
{
int a[]={,,,,};
Sorted(a,);
for(int i=;i<;i++)
cout<<"-----------"<<a[i]<<endl;
return ;
} void Sorted(int* x, int length)
{
for(int i=; i<length;i++ )
{
int temp=x[i];
int j=i-;
while( j>= && temp<x[j])
{
x[j+]=x[j];
x[j]=temp;
j--;
}
}
}

  在上面的例子里面:

 a[]={,,,,};

  在每一步的运算过程中,其数据的变化如下:

   

 

  上述描述了比较的过程。

  柱状图表表示了每一个位置的数字大小,蓝色区域为无序部分,黄色部分为经过一次运算之后的有序部分。

  其主要步骤是,选择无序部分的第一个元素,将其插入到黄色的有序部分里面去,这样黄色区域扩展,而蓝色区域则是不断地减小,直至所有的区域变为有序状态。

复杂度分析:

  可以看到,上述过程,主要操作是比较操作,然后是赋值操作,其中赋值操作的所花费的时间更长

  在最好的情况下,整个数据正好是升序排列的,这个时候比较操作是(n-1),赋值操作 复杂度为0

  在最坏的情况下,整个数据是降序排列的,这个时候比较次数是  n*(n-1)/2 次,赋值操作是4*n*(n-1)/2, 主要的时间花在了赋值的操作上,时间复杂度为O(n2)

  稳定性来说,这个算法是不稳定的,即相同的两个元素,在排序前和排序之后,先后次序可能发生了改变。

三、选择排序

  选择排序的思想与上面的插入排序相同,将数据分为有序部分和无序部分。

  在无序部分里面选择出最值(比如说是最大值,放到有序部分),这样经过不断的选择无序部分的最大值,使得有序部分不断的扩展,无序部分不断地缩小,最后得到整个有序数据序列。

  具体代码如下:

 #include <iostream>
using namespace std;
void Sorted(int* x, int length);
int main(void)
{
int a[] = { ,,,,};
Sorted(a, );
for (int i = ; i < ; i++)
cout << "-----------" << a[i] << endl;
return ;
} void Sorted(int* x, int length)
{
int max = ;
int len = length - ; for (int i = ; i <= length-; i=i+)
{
max = x[];
int j = ;
int number = ;
for (j = ; j <= len; j++)
{
if (max < x[j])
{
max = x[j];
number = j;
}
}
int temp = x[len];
x[len] = max;
x[number] = temp;
len--;
}
}

其每一次的比较过程如下:

 

如图可以看到,有序的黄色区域在不断的扩展,无序部分在逐渐减少。

复杂度:

  最好情况:全是升序排列,这个时候只需要(n-1)次比较

  最坏情况:全是降序排列,这个时候需要(n-1)*n/2次比较,(n-1)次互换操作,时间复杂度在O(n) (这里只是考虑了互换操作), 比冒泡排序法快

  稳定性:不稳定

  

三、排序算法总结一(冒泡排序,插入排序,选择排序)(C++版本)的更多相关文章

  1. PHP算法排序之快速排序、冒泡排序、选择排序、插入排序性能对比

    <?php //冒泡排序 //原理:从倒数第一个数开始,相邻的两个数比较,后面比前面的小,则交换位置,一直到比较第一个数之后则最小的会排在第一位,以此类推 function bubble_sor ...

  2. 【程序员笔试面试必会——排序①】Python实现 冒泡排序、选择排序、插入排序、归并排序、快速排序、堆排序、希尔排序

    最近在准备笔试题和面试题,把学到的东西整理出来,一来是给自己留个笔记,二来是帮助大家学习. 题目: 给定一个int数组A及数组的大小n,请返回排序后的数组. 测试样例:  输入:[1,2,3,5,2, ...

  3. 排序方法整理Java - 冒泡排序、选择排序、插入排序、快速排序

    /** * 排序方法整理 * @author zhyea * */ public class Sort { /** * 冒泡排序,从小到大. * 冒泡排序是比较相邻的两个元素,若顺序错误,则执行交换. ...

  4. JavaScript中数组的排序方法:1.冒泡排序 2.选择排序

      //1.选择排序: //从小到大排序:通过比较首先选出最小的数放在第一个位置上,然后在其余的数中选出次小数放在第二个位置上,依此类推,直到所有的数成为有序序列. var arr2=[19, 8, ...

  5. 《算法4》2.1 - 选择排序算法(Selection Sort), Python实现

    选择排序算法(Selection Sort)是排序算法的一种初级算法.虽然比较简单,但是基础,理解了有助于后面学习更高深算法,勿以勿小而不为. 排序算法的语言描述: 给定一组物体,根据他们的某种可量化 ...

  6. JavaScript算法(冒泡排序、选择排序与插入排序)

    冒泡排序.选择排序与插入排序复杂度都是二次方级别的,放在一起说吧. 介绍一些学习这三个排序方法的比较好的资料.冒泡排序看<学习JavaScript数据结构与算法>介绍的冒泡排序,选择排序看 ...

  7. Java数据结构和算法总结-冒泡排序、选择排序、插入排序算法分析

    前言:排序在算法中的地位自然不必多说,在许多工作中都用到了排序,就像学生成绩统计名次.商城商品销量排名.新闻的搜索热度排名等等.也正因为排序的应用范围如此之广,引起了许多人深入研究它的兴趣,直至今天, ...

  8. 【排序算法】——冒泡排序、选择排序、插入排序、Shell排序等排序原理及Java实现

    排序 1.定义: 所谓排序,即是整理文件中的内容,使其按照关键字递增或递减的顺序进行排列. 输入:n个记录,n1,n2--,其对应1的关键字为k1,k2-- 输出:n(i1),n(i2)--,使得k( ...

  9. java面向对象的冒泡排序,选择排序和插入排序的比较

    这三种排序有俩个过程: 1.比较俩个数据. 2.交换俩个数据或复制其中一项. 这三种排序的时间级别 冒泡排序:比较 (N-1)+(N-2)+...+2+1 = N*(N-1)/2=N2/2 交换  0 ...

  10. 「浙江理工大学ACM入队200题系列」问题 A: 零基础学C/C++34—— 3个数比较大小(冒泡排序与选择排序算法)

    本题是浙江理工大学ACM入队200题第四套中的A题,同时给出了冒泡排序和选择排序算法 我们先来看一下这题的题面. 由于是比较靠前的题目,这里插一句.各位新ACMer朋友们,请一定要养成仔细耐心看题的习 ...

随机推荐

  1. centos python3 的 卸载 删除

    卸载/删除python 3.4看到网上说慎用 apt-get remove和 yum remove ,因此不敢用此类命令用卸载了(以后阿里云服务器快过期不用了的时候可以试一下,看看系统是否会崩,哈哈) ...

  2. [PHP] 解决php中上传大文件的错误

    修改nginx配置文件,下面这个参数client_max_body_size 110M; 修改php配置文件中下面两个参数在php.ini中找到下面两个配置,配置项给改大,如果找不到php.ini的位 ...

  3. 使用java代码操作Redis

    1导入pom.xml依赖 <dependency> <groupId>redis.clients</groupId> <artifactId>jedis ...

  4. elementui入门以及nodeJS环境搭建

    1. ElementUI简介 我们学习VUE,知道它的核心思想式组件和数据驱动,但是每一个组件都需要自己编写模板,样式,添加事件,数据等是非常麻烦的, 所以饿了吗推出了基于VUE2.0的组件库,它的名 ...

  5. (day58)十、Cookie、Session、Token、Django中间件

    目录 一.Cookie (一)由来 (二)什么是Cookie (三)Django中操作Cookie (1)设置Cookie (2)获取Cookie (3)删除Cookie 二.Session (一)由 ...

  6. python 编程2

    一.课堂练习 描述 使用input输入若干个数,输出个数以及其中最大的数 1.普通方法实现 def max(*a): m=a[0] b=0 for x in a: if x>m: m=x b+= ...

  7. 数据库访问接口(ODBC,OLEDB,ADO)

    数据库访问接口发展历史 ODBC历史 ODBC(Open Database Connectivity,开放数据库互连).要了解ODBC是什么,先了解一下数据库连接的相关知识.在最开始连接数据库时,由于 ...

  8. Codeforces Round #594 (Div. 1) C. Queue in the Train 模拟

    C. Queue in the Train There are

  9. HTML连载45-浮动元素脱标、排序规则、贴靠现象

    一.浮动元素脱标 1.什么是浮动元素脱标 脱标:脱离标准流. 当某一个元素浮动之后,那么这个元素看上去就像被从标准流中删除了一样 2.浮动元素脱标之后有什么影响 如果前面一个元素浮动了,而后面的一个元 ...

  10. 使用layer.msg 时间设置不起作用

    前几天使用layer.msg设置时间后发现不起作用,这里记录一下. 开始出错误的代码: 后面查看文档后得知调用layer.msg后如果有后续操作需要写在function()中: //eg1 layer ...