温(Xue)习排序算法
最近忙着找工作,虽然排序算法用得到的情况不多,但不熟悉的话心里始终还是感觉没底。
于是今天给温习了其中的四个排序算法(与其说是温习,不如说是学习、、、因为感觉自己好像从来木有掌握过它们、、、)
一、选择排序
简单粗暴:将无序区变为有序区,每次将无序区中最小的挑选到最前面形成有序区。
例子:
5 3 7 8 4 原始数组
3 5 7 8 4 将3与5交换,因为后面的数字都比3大,所以不会再产生交换
3 4 7 8 5 同上,将 4与5交换
3 4 5 8 7 将5与7交换
3 4 5 7 8 将7与8交换
3 4 5 7 8
代码:
/// <summary>
/// 选择排序
/// </summary>
/// <param name="nList"></param>
public static void SelectSort(int[] nList)
{
for (int i = ; i < nList.Length; i++)
{
for (int j = i; j < nList.Length; j++)
{
if (nList[j] < nList[i])
{
int nTemp = nList[i];
nList[i] = nList[j];
nList[j] = nTemp;
}
}
}
}
二、冒泡排序
生动形象:每一轮都将无序区中最大的数字弄到最后面,像冒泡一样
5 3 7 8 4 原始数组
3 5 7 8 4 比较5与3,发现5比3大,交换之
3 5 7 8 4 比较5与7,不变
3 5 7 8 4 比较7与8,不变
3 5 7 4 8 将4与8交换
3 5 7 4 剩下的无序区,重复以上步骤即可
代码:
/// <summary>
/// 冒泡排序
/// </summary>
/// <param name="nList"></param>
public static void BubbleSort(int[] nList)
{
for (int i = nList.Length - ; i > ; i--)
{
for (int j = ; j < i; j++)
{
if (nList[j] > nList[j + ])
{
int nTemp = nList[j];
nList[j] = nList[j + ];
nList[j + ] = nTemp;
}
}
}
}
三、插入排序
望文生义:将元素插入到已经排序好的区域
3 5 7 8 4 原始数组
3 5 7 8 4 从5开始插入,直接放在末尾
3 5 7 8 4 将7放到末尾
3 5 7 8 4 将8放到末尾
3 4 5 7 8 将8、7、5后移,将4插入
代码:
/// <summary>
/// 插入排序
/// </summary>
/// <param name="nList"></param>
public static void InserSort(int[] nList)
{
int nTemp;
for (int i = ; i < nList.Length; i++)
{
nTemp = nList[i];//记住待插入元素
for (int j = i - ; j >= ; j--)
{
//若待插元素比当前元素小,则将当前元素往后移
if (nList[j] > nTemp)
{
nList[j + ] = nList[j]; if (j == )
{
nList[] = nTemp;
}
}
//反之,待插元素大于等于当前元素,则将待插元素放到当前元素的后面即可,并终止本轮循环
else
{
nList[j + ] = nTemp;
break;
}
}
}
}
四、快速排序
快成一道闪电:改良的冒泡排序(但相对前面三种方法,掌握起来就要慢一些了。。。)
3 5 7 8 4 哨兵:3 nLeft :5 nRight:4
、、、发现用这个来作为例子显然不合适嘛、、、来个加长版的,OK?
72 6 57 88 60 42 83 73 48 85 哨兵:72
x i j
取出72(此时nList为空),从j开始向左找到第一个比72小的数字:48,将其放到nList[0]中。
48 6 57 88 60 42 83 73 空 85
再从i开始向右找到第一个比72大的数,放到“空”的位置(注意,当i == j时此轮排序结束,所以要加判定)
48 6 57 空 60 42 83 73 88 85
重复以上步骤
48 6 57 42 60 空 83 73 88 85 此时 J 和 I会在“空”处相等,将前面的72填入“空”
48 6 57 42 60 72 83 73 88 85
后面用分治法继续快速排序[48,6,57,42,60]与[83,73,88,85]即可
代码:
/// <summary>
/// 快速排序
/// </summary>
public static void QuickSort(int[] nList,int nLow,int nHigh)
{
//终止条件
if (nLow >= nHigh)
{
return;
}
//当nLeft 等于 nRight之时,结束此轮快速排序
int nLeft = nLow;
int nRight = nHigh; int nTemp = nList[nLow]; while(nLeft < nRight)
{
while(nLeft < nRight && nList[nRight] >= nTemp)
{
nRight--;
}
if (nLeft < nRight)
{
nList[nLeft++] = nList[nRight];
}
while (nLeft < nRight && nList[nLeft] <= nTemp)
{
nLeft++;
}
if (nLeft < nRight)
{
nList[nRight--] = nList[nLeft];
}
} nList[nLeft] = nTemp; QuickSort(nList, nLow, nLeft - );
QuickSort(nList, nLeft + , nHigh); }
温(Xue)习排序算法的更多相关文章
- 常用排序算法总结(C语言描述)
最近又把排序给复(yu)习(xi)了一遍,在此总结一下~具体理论思想持续补充完善中... 1.交换排序 (1)普通冒泡 时间复杂度:最差.平均都是O(n^2),最好是O(n) 空间复杂度:O(1) # ...
- JavaScript实现常用的排序算法
▓▓▓▓▓▓ 大致介绍 由于最近要考试复习,所以学习js的时间少了 -_-||,考试完还会继续的努力学习,这次用原生的JavaScript实现以前学习的常用的排序算法,有冒泡排序.快速排序.直接插入排 ...
- 排序算法----基数排序(RadixSort(L))单链表智能版本
转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...
- 常见排序算法(附java代码)
常见排序算法与java实现 一.选择排序(SelectSort) 基本原理:对于给定的一组记录,经过第一轮比较后得到最小的记录,然后将该记录与第一个记录的位置进行交换:接着对不包括第一个记录以外的其他 ...
- 几大排序算法的Java实现
很多的面试题都问到了排序算法,中间的算法和思想比较重要,这边我选择了5种常用排序算法并用Java进行了实现.自己写一个模板已防以后面试用到.大家可以看过算法之后,自己去实现一下. 1.冒泡排序:大数向 ...
- 排序算法----基数排序(RadixSort(L,max))单链表版本
转载http://blog.csdn.net/Shayabean_/article/details/44885917博客 先说说基数排序的思想: 基数排序是非比较型的排序算法,其原理是将整数按位数切割 ...
- 排序算法汇总(C/C++实现)
前言: 本人自接触算法近2年以来,在不断学习中越多地发觉各种算法中的美妙.之所以在这方面过多的投入,主要还是基于自身对高级程序设计的热爱,对数学的沉迷.回想一下,先后也曾参加过ACM大大小小的 ...
- 用Java来写常见的排序算法
随着校招的临近 算法是校招中很重要的一个部分 总结了常见几种排序算法,各种算法的时间复杂度和空间复杂度大家也需要多了解下 package com.huwei.sort; /** * 各种排序算法 * ...
- 模板化的七种排序算法,适用于T* vector<T>以及list<T>
最近在写一些数据结构以及算法相关的代码,比如常用排序算法以及具有启发能力的智能算法.为了能够让写下的代码下次还能够被复用,直接将代码编写成类模板成员函数的方式,之所以没有将这种方式改成更方便的函数模板 ...
随机推荐
- 第12课:HTML基础之DOM操作1
DOM(Document Object Model):文本对象模型 dom对象实际上是html页面转成成的文本对象,可以通过dom对象中js提供的方法找到htm中的各个标签. 练习URL:http:/ ...
- Beta阶段第2周/共2周 Scrum立会报告+燃尽图 11
作业要求[https://edu.cnblogs.com/campus/nenu/2018fall/homework/2411] 版本控制:https://git.coding.net/liuyy08 ...
- opencv之访问图像像素
访问像素的三种方法 ①指针访问:最快 ②迭代器iterator:较慢,非常安全,指针访问可能出现越界问题 ③动态地址计算:更慢,通过at()实现.适用于访问具体某个第i行,j列的像素,而不适用遍历像素 ...
- CH3301 同余方程
题意 3301 同余方程 0x30「数学知识」例题 描述 求关于 x的同余方程 ax ≡ 1(mod b) 的最小正整数解. 输入格式 输入只有一行,包含两个正整数a,b,用一个空格隔开. 输出格式 ...
- C# 4.0中的动态类型和动态编程
# 4.0的主题就是动态编程(Dynamic Programming).虽然C#仍然是一种静态语言,但是对象的意义开始变得越来越“动态”.它们的结构和行为无法通过静态类型来捕获,或者至少编译器在编译程 ...
- c# 子线程如何通知主线程,个人总结
我要实现的功能如下:程序中有2个线程,主线程和子线程,主线程中有一个变量:X主线程运行中激活子线程,子线程会做出计算改变 X 的值,主线程继续做其它的事,直到 X 的值发生改变时,才会响应,并在tex ...
- baby用品
新生嬰兒用品清單 1.哺育用品: 大奶瓶:6支,240ml左右.選擇PC材質耐高溫120度,可消毒:玻璃材質建議選用印刷安全無鉛材料,可消毒. 小奶瓶:2-3支,120ml左右.寬口徑/一般口徑(喝水 ...
- C# 与 Oracle 中 BINARY_DOUBLE数据类型查询
Oracle 10g新增 BINARY_DOUBLE 数据类型,而.NET暂不支持这个类型,查询时需要转换为 NUMBER. eg: "SELECT RAWTOHEX(OID) AS OID ...
- 总是有人问我,那你能造出你自己都搬不动的石头吗? 我说不能,但我能写出个我自己都无法 fix 的 bug。
总是有人问我,那你能造出你自己都搬不动的石头吗? 我说不能,但我能写出个我自己都无法 fix 的 bug.
- C++ 类成员的构造和析构顺序
我想对面向对象有了解的童鞋应该不会对类和对象感到陌生吧 ! 对象并不是突然建立起来的,创建对象必须时必须同时创建父类以及包含于其中的对象.C++遵循如下的创建顺序: (1)如果某个类具体基类,执行基类 ...