冒泡排序
基本思想:两两比较待排序的数,发现反序时交换,直到没有反序为止。
public static void BubbleSort(int[] R)
{
for (int i = 0; i < R.Length - 1; i++)
{
bool noswap = true;
for (int j = 0; j < R.Length - 1-i; j++)
{
if (R[j] > R[j + 1])
{
int temp = R[j];
R[j] = R[j + 1];
R[j + 1] = temp;
noswap = false;
}
}
if (noswap)
{
break;
}
}
} 快速排序
基本思想:在待排序数列中任选出一个数作为基准,用这个基准将数列划分为左右两个子区,使得左子区的数都不大于基准数,而右子区的数都不小于基准数,称为完成第一次划分。如果左子区或右子区不为空,则对它进行同样的划分,直至为空为止。
public static void QUICKSORT(int[] N,int left,int right)
{
//数组元素如果不大于一个就无需排序。
if (left < right)
{
int p = PARTITION(N, left, right); //第一次划分
QUICKSORT(N, left, p-1); //递归处理左子区
QUICKSORT(N, p+1, right); //递归处理右子区
}
}
//划分
public static int PARTITION(int[] R, int left,int right)
{
int i = left;
int j = right;
int temp = R[i];
while (i != j)
{
//从左往右扫描,查找第一个比基准数小的数
while ((R[j] >= temp) && (i<j))
{
j--;
}
if (i < j)
{
//交换找到的数和基准数,由于基准数还需交换多次,所以暂时不用将temp->R[j]
R[i] = R[j];
i++;
} while ((R[i] <= temp) && (i < j))
{
i++;
}
if (i< j)
{
R[j] = R[i];
j--;
}
}
//定位基准数
R[i] = temp;
return i;
} 直接选择排序
基本思想:每次从无序数组中选出一个最小的出来,放到已排好序的数组的最后。
public static void SELECTSORT(int[] R)
{
for (int i = 0; i < R.Length-1; i++)
{
int index = i;
for (int j = i + 1; j < R.Length; j++)
{
if (R[j] < R[index])
{
index = j;
}
}
//交换R[i]和R[index]
if (index != i)
{
int t = R[i]; R[i] = R[index]; R[index] = t;
}
}
} 插入排序
基本思想:首先将数组的第一个数sortArray[0]看成是有序的,然后从第二个元素开始和它前面的元素进行比较,如果比前面的某一个数大,就交换。由于前面的元素是有序的,所以就使有序元素的个数逐渐增大,直到等于n。
public void Sort(int[] sortArray)
{
int j = 0;
int key = 0; // key为哨兵
for (int i = 1; i < sortArray.Length; i++) //[0..i-1]已经排好的有序列
{
if (sortArray[i] < sortArray[i - 1])
{
key = sortArray[i];
j = i - 1;
while (j >= 0 && key < sortArray[j]) //当sortArray[i] ≥sortArray[j] 时终止
{
sortArray[j + 1] = sortArray[j];
j--;
}
sortArray[j + 1] = key; //插入到j的后面
}
}
} 希尔排序
基本思想:通过一个逐渐减小的增量使一个数组逐渐趋近于有序从而达到排序的目的。
public void SortShell(int [] list)
{
int i;
for(i=1;i<=list.Length/9;i=3*i+1);
for(;i>0;i/=3)
{
for(int i=i+1;i<=list.Length;i+=inc)
{
int t=list[i-1];
int j=i;
while((j>inc)&&(list[j-inc-1]>t))
{
list[j-1]=list[j-inc-1];
j-=inc;
}
list[j-1]=t;
}
}
} 堆排序
基本思想:记录区的分为无序区和有序区前后两部分;用无序区的数建大根堆,得到的根(最大的数)和无序区的最后一个数交换,也就是将该根归入有序区的最前端;如此重复下去,直至有序区扩展至整个记录区。 堆排序步骤:
第一步,根据初始输入数据,利用堆的调整算法形成初始堆。
第二步,通过一系列的记录交换和重新调整堆进行排序。
最大堆的向下调整算法:
调用了O(n)次Adjust()算法,堆排序的时间复杂性为O(nlog2n)。
该算法的附加存储主要是执行记录交换时所用的一个临时记录。
因此,该算法的空间复杂性为O(1)。
堆排序是一个不稳定的排序方法。 #include <stdio.h>
void swap(int &x, int &y)
{
int temp = x;
x = y;
y = temp;
}
void Adjust(int *a, int parent, int high)
{
int l = 2 * parent + 1;
int r = l + 1;
int flag = parent; if (l<=high && a[l]>a[flag])
{
flag = l;
}
if (r<=high && a[r]>a[flag])
{
flag = r;
}
if (flag != parent)
{
swap(a[parent], a[flag]);
Adjust(a, flag, high);
}
}
void HeapSort(int *a, int n)
{
int i; for (i=n-1; i>=0; i--)
{
Adjust(a, i, n - 1);
}
for (i=n-1; i>=0; i--)
{
swap(a[0], a[i]);
Adjust(a, 0, i - 1);
}
}
void Output(int *a, int n)
{
int i;
for (i=0; i<n; i++)
{
printf("\t%d", a[i]);
}
printf("\n");
}
int main()
{
int a[] = { 49, 38, 65, 97, 76, 13, 27, 49 };
int n = 8; Output(a, n);
HeapSort(a, n);
Output(a, n); return 0;
} /*
49 38 65 97 76 13 27 49
13 27 38 49 49 65 76 97
*/

C++数据结构中的基本算法排序的更多相关文章

  1. 彻底弄明白之数据结构中的KMP算法

    如何加速朴素查找算法? KMP,当然还有其他算法,后续介绍.      Knuth–Morris–Pratt string search algorithm Start at LHS of strin ...

  2. 数据结构中常用的排序算法 && 时间复杂度 && 空间复杂度

    第一部分:数据结构中常用的排序算法 数据结构中的排序算法一般包括冒泡排序.选择排序.插入排序.归并排序和 快速排序, 当然还有很多其他的排序方式,这里主要介绍这五种排序方式. 排序是数据结构中的主要内 ...

  3. [Data Structure] 数据结构中各种树

    数据结构中有很多树的结构,其中包括二叉树.二叉搜索树.2-3树.红黑树等等.本文中对数据结构中常见的几种树的概念和用途进行了汇总,不求严格精准,但求简单易懂. 1. 二叉树 二叉树是数据结构中一种重要 ...

  4. 数据结构中的棧在C#中的实现

    数据结构中的棧在C#中的实现 一.大致学习 棧是一种面向表的数据结构,棧中的数据只能在标的某一短进行添加和删除操作,是一种典型的(LIFO)数据结构. 现实生活中的理解:自助餐厅的盘子堆,人们总是从顶 ...

  5. Java--缓存热点数据,最近最少使用算法

    1.最近最少使用算法LRU (Least recently used,最近最少使用) [实现]:最常见的是使用一个链表保存缓存数据 1.新数据插入到链表头部: 2.每当缓存命中(即缓存数据被访问),将 ...

  6. JS的十大经典算法排序

    引子 有句话怎么说来着: 雷锋推倒雷峰塔,Java implements JavaScript. 当年,想凭借抱Java大腿火一把而不惜把自己名字给改了的JavaScript(原名LiveScript ...

  7. 浅析数据结构中栈与C实现

    最近在搞摄像头驱动,o()︿︶)o 唉,别提有多烦,一堆寄存器就有人受的了--特么这不是单片机的开发,这是内核驱动开发-- 今天放松一下,我们来看看数据结构中的栈,这节的知识点可以说是数据结构中最容易 ...

  8. 【编程练习】收集的一些c++代码片,算法排序,读文件,写日志,快速求积分等等

    写日志: class LogFile { public: static LogFile &instance(); operator FILE *() const { return m_file ...

  9. js算法排序

    一.选择算法排序(算法时间复杂度为O(n²)级别) 选择排序就是选择数组中的最小的树,依次排序.第一次选择最小的数放在第一位,第二次从剩余的元素中寻找最小的元素放在第二位,第三次在剩余的数中选择最小的 ...

随机推荐

  1. linux三剑客之一grep

    正则表达式(Regular Expression) 目录 起源 正则表达式是什么? 两类基本正则表达式 正则表达式元字符 Linux上文本三剑客 小试牛刀 总结 一.起源   正则表达式这个名词,相信 ...

  2. es6学习笔记--解构赋值

    昨天学习了es6语法中解构赋值,解构赋值在声明中和函数传参提高了灵活性和便捷性,值得掌握该语法. 概念: ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构.   数组的解构 ...

  3. NOIWC2018滚粗记

    Day0 \(THUWC\)刚刚结束..顺利的滚粗了 Day1 整理一下自己咸鱼的心 下午到学校坐车出发 这次队伍浩大THUWC只有4个 又到了雅礼洋湖这个地方 路上突然多了许多有关\(NOI\)的标 ...

  4. [SCOI2010]传送带

    在两个传送带上分别三分两个点计算 三分套三分 # include <bits/stdc++.h> # define IL inline # define RG register # def ...

  5. Java集合中迭代器的常用用法

    该例子展示了一个Java集合中迭代器的常用用法public class LinkedListTest { public static void main(String[] args) { List&l ...

  6. link 标签

    link标签 主要是引用外部文件 rel属性 规定当前文档与被链接文档之间的关系 alternate,author,help,icon,licence,next,pingback,prefetch,p ...

  7. cocos creator实现棋牌游戏滑动选牌的功能

    最近在玩cocos creator,打算学着做一款类似双扣游戏的棋牌,名字叫文成三星,比双扣还要多一扣,因为需要三幅牌,在我们老家比较流行这种玩法. 目前实现了绝大部分的逻辑效果如下: 有一点不好的体 ...

  8. zabbix添加自定义监控项

    zabbix添加自定义监控项 author:headsen  chen   2017-10-16  17:23:17 个人原创,转载请注明作者,出处,否则依法追究法律责任 主机端配置: 首先安装好za ...

  9. SpringBoot工作机制

    1:前言 回顾探索Spring框架 1.spring ioc IoC其实有两种方式,一种就是DI,而另一种是DL,即Dependency Lookup(依赖查找),前者是当前软件实体被动接受其依赖的其 ...

  10. 在oracle中,group by后将字符拼接,以及自定义排序

    1.在oracle中,group by后将字符拼接.任务:在学生表中,有studentid和subject两个字段.要求对studentid进行group by分组,并将所选科目拼接在一起.oracl ...