一、排序的概念
💡 排序 (Sorting) 是计算机程序设计中的一种重要操作,它的功能是将一个数据元素(或记录)的任意序列,重新排列成一个关键字有序(升序或者降序)的序列.
- 稳定性
![](https://img-blog.csdnimg.cn/img_convert/37cbe0775fcb1544aba9e7b625fa35d5.png#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=272&id=u230ff4d7&margin=[object%20Object]&name=image.png&originHeight=327&originWidth=722&originalType=binary&ratio=1&rotation=0&showTitle=false&size=16846&status=done&style=none&taskId=u35b61d5f-79a5-4c88-a28d-7a78bfaf105&title=&width=601.6666427585823)
- 内部排序: 数据在内存中进行排序.
- 外部排序: 数据在磁盘中进行排序.
二、排序的运用
![](https://img-blog.csdnimg.cn/img_convert/01454d09881f5df06fd2374142370ac4.png#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=698&id=uce190696&margin=[object%20Object]&name=image.png&originHeight=838&originWidth=1890&originalType=binary&ratio=1&rotation=0&showTitle=false&size=805363&status=done&style=none&taskId=u235a1426-721f-496e-b4e9-df4cfb23391&title=&width=1574.9999374151255)
中国计算机学校排名:
![](https://img-blog.csdnimg.cn/img_convert/f1e01fe31a90d9cc79d734c1aed826f5.jpeg#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=ui&id=u64d8081c&margin=[object%20Object]&name=3.jpg&originHeight=356&originWidth=408&originalType=binary&ratio=1&rotation=0&showTitle=false&size=23105&status=done&style=none&taskId=uc51218b9-d996-4324-8c74-1b6c82a9d89&title=)
三、常见排序算法
![](https://img-blog.csdnimg.cn/img_convert/8fc56cd6323880ca0d64fc782023aa6a.png#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=477&id=u40a0f92e&margin=[object%20Object]&name=image.png&originHeight=572&originWidth=886&originalType=binary&ratio=1&rotation=0&showTitle=false&size=97581&status=done&style=none&taskId=u371b447d-b9d2-4c9b-b193-9384a77759c&title=&width=738.3333039946037)
1.插入排序
插入排序是一种最简单直观的排序算法,它的基本思想是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入.
![](https://img-blog.csdnimg.cn/img_convert/a29b0a48f3f76fff617df84c0639e882.png#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=528&id=uc89b5692&margin=[object%20Object]&name=image.png&originHeight=634&originWidth=1152&originalType=binary&ratio=1&rotation=0&showTitle=false&size=17292&status=done&style=none&taskId=u7c14ef53-c9e6-4dc8-9bc0-07a81d7948a&title=&width=959.9999618530288)
public static void insertSort(int arr[]) {
for (int i = 1; i < arr.length; i++) {
int tmp = arr[i];
int j = i-1;
for (; j >= 0; j--) {
if(arr[j] > tmp) {
arr[j+1] = arr[j];
}else {
// arr[j+1] = tmp;
break;
}
}
arr[j+1] = tmp;
}
}
2.希尔排序
希尔排序(Shell’s Sort)是插入排序的一种又称“缩小增量排序”(Diminishing Increment Sort),是直接插入排序算法的一种更高效的改进版本.该方法因 D.L.Shell 于 1959 年提出而得名.
![](https://img-blog.csdnimg.cn/img_convert/e451b1e0867107c0ccca49524d75d80f.jpeg#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=ui&id=u8d1d68bf&margin=[object%20Object]&name=5.jpg&originHeight=1413&originWidth=765&originalType=binary&ratio=1&rotation=0&showTitle=false&size=51631&status=done&style=none&taskId=u8d99547b-6361-4e58-b694-b373cc4557a&title=)
public static void shell(int arr[],int gap) {
for (int i = gap; i < arr.length; i++) {
int tmp = arr[i];
int j = i-gap;
for (; j >= 0; j-=gap) {
if(arr[j] > tmp) {
arr[j+gap] = arr[j];
}else {
// arr[j+1] = tmp;
break;
}
}
arr[j+gap] = tmp;
}
}
public static void shellSort(int arr[]) {
int gap = arr.length;
while (gap > 1) {
shell(arr,gap);
gap /= 2;
}
shell(arr,1);
}
3.选择排序
基本思想:第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的开始的位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾。
![](https://img-blog.csdnimg.cn/img_convert/b62031e274dffe6742170509a3960034.png#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=382&id=ub23e5325&margin=[object%20Object]&name=image.png&originHeight=458&originWidth=1061&originalType=binary&ratio=1&rotation=0&showTitle=false&size=14386&status=done&style=none&taskId=u27722481-3272-4967-92c4-23e096f9e2c&title=&width=884.1666315330414)
public static void selectSort(int arr[]) {
for (int i = 0; i < arr.length-1; i++) {
for (int j = i+1; j < arr.length; j++) {
if(arr[i] > arr[j]) {
arr[i] = arr[i] ^ arr[j];
arr[j] = arr[i] ^ arr[j];
arr[i] = arr[i] ^ arr[j];
}
}
}
}
4.冒泡排序
基本思想: 比较相邻的两个元素。如果第一个比第二个大,就进行数据的交换。
public static void bubblingSort(int[] arr) {
for (int i = 0; i < arr.length-1; i++) {
for (int j = 0; j < arr.length-1-i; j++) {
if(arr[j] > arr[j+1]) {
arr[j] = arr[j] ^ arr[j+1];
arr[j+1] = arr[j] ^ arr[j+1];
arr[j] = arr[j] ^ arr[j+1];
}
}
}
}
四、测试效率
public static void main2(String[] args) {
int arr[] = new int[10_0000];
Random random = new Random();
for (int i = 0; i < arr.length; i++) {
arr[i] = random.nextInt(10_0000);
}
long beg = System.currentTimeMillis();
//shellSort(arr);
insertSort(arr);
long end = System.currentTimeMillis();
System.out.println(end-beg);
}
结论:
![](https://img-blog.csdnimg.cn/img_convert/2e2203f4bd98ac1234f3ebbfd203d65c.png#clientId=u2f5efc4a-34eb-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=164&id=u102b25c5&margin=[object%20Object]&name=image.png&originHeight=197&originWidth=633&originalType=binary&ratio=1&rotation=0&showTitle=false&size=20738&status=done&style=none&taskId=u4cb06883-5331-425f-8544-3539f703f63&title=&width=527.4999790390341)
![](https://img-blog.csdnimg.cn/13069106170d4c1e85e42504bfe468a8.png)