排序算法总结(C++版)
总结下学过的排序算法,方便以后用到。
1.插入排序——将一个记录插入到已排序好的有序表中,从而得到一个新,记录数增1的有序表。
void insertSort(int a[],int len)
{
for(int i = ;i < len;i ++)
{
int j = i;
int x = a[j]; //要插入的数
while(j > && x < a[j - ]) //将大的数推上去,空出个位置
{
a[j] = a[j - ];
j--;
}
a[j] = x; //插入
}
}
2.冒泡排序——不断地比较相邻2个数的大小,大的就推到后面,最后把最大值推到了最后,依次类推。
void swap(int &a,int &b)
{
int tmp = a;
a = b;
b = tmp;
} void bubbleSort(int a[],int len)
{
for(int i = len - ;i > ;i --)
for(int j = ;j < i;j ++)
if(a[j] > a[j + ])
swap(a[j],a[j + ]);
}
3.选择排序——第一次选出数组中最小的数与第一个数交换位置,第二次选出第二小的与第二个数交换位置,以此类推。
//swap函数见上。
void selectSort(int a[],int len)
{
for(int i = ;i < len - ;i ++)
{
int min = a[i];
int minPos = i;
for(int j = i + ;j < len;j ++)
{
if(a[j] < min)
{
min = a[j];
minPos = j;
}
}
if(minPos != i)
swap(a[i],a[minPos]);
}
}
4.归并排序——将一个序列分成2个长度相等的子序列,分别排序,然后再将它们合并成一个有序的序列。(合并的过程比较麻烦,这里利用一个辅助数组来将排好序的子序列先复制过去,然后再归并回原数组)
void mergeSortHelp(int a[],int tmp[],int left,int right)
{
if(left == right)
return;
int mid = (left + right) / ;
mergeSortHelp(a,tmp,left,mid);
mergeSortHelp(a,tmp,mid + ,right);
for(int i = left;i <= right;i ++)
tmp[i] = a[i];
int i = left;
int j = mid + ;
int k = left;
while(k <= right)
{
if(j > right)
a[k++] = tmp[i++];
else if(i > mid)
a[k++] = tmp[j++];
else if(tmp[i] < tmp[j])
a[k++] = tmp[i++];
else a[k++] = tmp[j++];
}
} void mergeSort(int a[],int len)
{
int *tmp = new int[len];
mergeSortHelp(a,tmp,,len - );
delete []tmp;
}
5.快速排序——选择数组中的一个数作为轴值(这里选择第一个数),将小于轴值的数放到左边,大的放到右边,轴值放中间,这样只需要各自递归快排左右两边数组,完成排序。
//swap函数见上上上
int partition(int a[],int left,int right)
{
int pivotPos = left; //记录轴值位置
int pivot = a[left]; //取最左边的值作为轴值
left ++; //避开轴值
while(left < right) //从左右两边各自扫描数组,左边遇到比轴值大的就停下,右边遇到比轴值小的就停下,交换。继续。。。
{
while(a[left] < pivot && left < right)
left++;
while(a[right] > pivot && left < right)
right--;
swap(a[left],a[right]);
}
if(a[right] < a[pivotPos])
{
swap(a[right],a[pivotPos]);
return right;
}else
{
swap(a[right - ],a[pivotPos]);
return right - ;
}
} void quickSortHelp(int a[],int left,int right)
{
if(left >= right)
return; int k = partition(a,left,right); //通过partition将数组按比轴值大小分别放到轴值左右两边,返回最后轴值的位置k。 quickSortHelp(a,left,k - );
quickSortHelp(a,k + ,right);
}
void quickSort(int a[],int len)
{
quickSortHelp(a,0,len - 1);
}
6.堆排序(夜深下次再写)
排序算法总结(C++版)的更多相关文章
- 常见排序算法(JS版)
常见排序算法(JS版)包括: 内置排序,冒泡排序,选择排序,插入排序,希尔排序,快速排序(递归 & 堆栈),归并排序,堆排序,以及分析每种排序算法的执行时间. index.html <! ...
- 十大经典排序算法总结——JavaScrip版
首先,对于评述算法优劣术语的说明: 稳定:如果a原本在b前面,而a=b,排序之后a仍然在b的前面:即排序后2个相等键值的顺序和排序之前它们的顺序相同 不稳定:如果a原本在b的前面,而a=b,排序之后a ...
- 十大经典排序算法的JS版
前言 个人博客:Damonare的个人博客 如遇到问题或有更好的优化方法,可以: 提issue给我 或是pull requests 我都会看到并处理,欢迎Star. 这世界上总存在着那么一些看似相似但 ...
- 选择排序---直接选择排序算法(Javascript版)
在要排序的一组数列中,选出最小(或者最大)的一个数与第1个位置的数交换:然后在剩下的数当中再找最小(或者最大)的与第2个位置的数交换,依次类推,直到第n-1个元素(倒数第二个数)和第n个元素(最后一个 ...
- 【Unity3D自学记录】可视化对照十多种排序算法(C#版)
在这篇文章中.我会向大家展示一些排序算法的可视化过程.我还写了一个工具.大家可对照查看某两种排序算法. 下载源代码 – 75.7 KB 下载演示样例 – 27.1 KB 引言 首先,我觉得是最重要的是 ...
- 面试常用算法总结——排序算法(java版)
排序算法 重要性不言而喻,很多算法问题往往选择一个好的排序算法往往问题可以迎刃而解 1.冒泡算法 冒泡排序(Bubble Sort)也是一种简单直观的排序算法.它重复地走访过要排序的数列,一次比较两个 ...
- 排序算法总结(C#版)
算法质量的衡量标准: 1:时间复杂度:分析关键字比较次数和记录的移动次数: 2:空间复杂度:需要的辅助内存: 3:稳定性:相同的关键字计算后,次序是否不变. 简单排序方法 .直接插入排序 直接插入排序 ...
- 排序算法(java版)
一直想理解一下基本的排序算法,最近正好在搞java所以就一并了(为了便于理解,这儿都是以从小到大排序为目的) 冒泡排序 也就是比较连续的两个值,如果前面一个值大于后面一个值,则交换. 时间复杂度为O( ...
- 经典排序算法(Java版)
1.冒泡排序 Bubble Sort 最简单的排序方法是冒泡排序方法.这种方法的基本思想是,将待排序的元素看作是竖着排列的“气泡”,较小的元素比较轻,从而要往上浮.在冒泡排序算法中我们要对这个“气泡” ...
- 排序算法 Java实现版
8种排序之间的关系: 1. 直接插入排序 (1)基本思想: 在要排序的一组数中,假设前面(n-1)[n>=2] 个数已经是排好顺序的,现在要把第n个数插到前面的有序数中,使得这n个数也是排好顺序 ...
随机推荐
- php-laravel4.0框架 简单快速入门
前提必须已经安装好了laravel4.0版本. 写入权限: 安装完 Laravel ,你还需要为web服务器设置 app/storage 目录的写入权限. 目录结构: 安装完框架后,你需要熟悉一下该项 ...
- Linux SSH 安装Tomcat
tomcat的安装 1. 下载tomcat 从tomcat官网(http://tomcat.apache.org/download-70.cgi)下载tomcat的压缩包apache-tomcat-7 ...
- 推荐一个比FiddlerCore好用的HTTP(S)代理服务器
为什么不用FiddlerCore? 说到FiddlerCore大家可能会比较陌生,那么它哥Fiddler就比较熟悉了:抓包.模拟低带宽.修改请求我平时比较常用.Fiddler的本质就是一个HTTP代理 ...
- ArrayList,LinkedListd等容器使用时注意点:
1.对这两个List(包括其他的类似容器),如果向里面加入一个元素(引用数据类型),那么这个List里面保存的是这个对象的引用: 如果想要避免这种现象可以这样:在加入新的元素时不直接压,将已有的对象复 ...
- springmvc返回枚举属性值
使用fastJSON ,在枚举中写toString 方法 如下@Overridepublic String toString() {return "{" + this.name() ...
- spring事务不会进行回滚的情况
if(userSave){ try { userDao.save(user); userCapabilityQuotaDao.save(capabilityQuota); } catch (Excep ...
- 51nod 1414 冰雕 思路:暴力模拟题
题意是现在有n个雕像把一个圆等分了,每一个雕像有一个吸引力. 叫你不移动雕像只去掉雕像让剩下的雕像还能等分这个圆,求剩下的雕像的吸引力之和的最大值. 显然去掉后剩下雕像的间隔应该是n的因子,因为这样才 ...
- Gate One——用web展示Terminal(安装)
Gate One可以用web来展示Terminal,虽然存在一些小缺陷,基本功能都还可以的,有兴趣的可以折腾一下. 安装环境: 系统:RHEL 6.1 ,系统自带python 2.6.6 下载需要安装 ...
- Jmeter脚本调试——关联(正则表达式)
关联,在脚本中,是必应用到的一个设置方法,将脚本中,每次都会动态变化的特殊值进行关联.一个能正确执行的脚本,都需要进行关联(LR.jmeter). Jmeter关联: 在脚本回放过程中,客户端发出请求 ...
- 三大开源运维监控工具zabbix、nagios、open-falcon优缺点比较
借鉴一下别人的,自己做个记录,我觉得推荐还是使用open-falcon,最重要的一点是有完善的中文帮助文档. 帮助文档地址:https://book.open-falcon.org/zh/index. ...