排序,有内排序和外排序

内排序,是在内存中进行

外排序,是在磁盘上进行

内排序根据是否使用比较大小的方法,又分比较排序和非比较排序

首先,Java中自已是有排序的

说明:
(1)Arrays类中的sort()使用的是“经过调优的快速排序法”;
(2)比如int[],double[],char[]等基数据类型的数组,Arrays类之只是提供了默认的升序排列,没有提供相应的降序排列方法。
(3)要对基础类型的数组进行降序排序,需要将这些数组转化为对应的封装类数组,如Integer[],Double[],Character[]等,对这些类数组进行排序。(其实还不如先进行升序排序,自己在转为将序)。

import java.util.Arrays;

public class TestSort {

    int a[] = {1, 2, 3, 4, 5, 6, 7};
int temp; @Test(priority = 1, description = "利用Arrays中的Sort函数排序")
public void ArraysSort() {
Arrays.sort(a);
for (int i = 0; i < a.length; i++) {
System.out.println(a[i]);
}
} }

  

Step01:冒泡排序

原理:比较两个相邻的元素,将值大的元素交换至一端。

思路:依次比较相邻的两个数,将小数放在前面,大数放在后面。
即在第一趟:首先比较第1个和第2个数,将小数放前,大数放后。
然后比较第2个数和第3个数,将小数放前,大数放后,
如此继续,直至比较最后两个数,将小数放前,大数放后。

重复第一趟步骤,直至全部排序完成。

public class Sort01_BubbleSort {

    public static void main(String agrs[]) {

        int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 0};
System.out.println("\n"+arr.length);
System.out.println("before sort:");
for (int num : arr) {
System.out.print(num + " ");
} 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]) {//if 后一位的数小,将被往前移动
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
System.out.println("\n"+"---第"+(i+1)+"轮第"+(j+1)+"次-----");
for (int num : arr) {
System.out.print(num + " ");
} }
}
System.out.println("\n"+"---");
System.out.println("after sort:");
for (int num : arr) {
System.out.print(num + " ");
}
}
}

  查看具体执行的过程:

"C:\Program Files\Java\jdk1.8.0_161\bin\java" "-javaagent:C:\Program Files\JetBrains\IntelliJ IDEA 2018.1\lib\idea_rt.jar=55246:C:\Program Files\JetBrains\IntelliJ IDEA 2018.1\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.8.0_161\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\rt.jar;D:\00M_IDEA_Project\mavenDemo_idea01\target\classes" Sort01_BubbleSort

10
before sort:
1 2 3 4 5 6 7 8 9 0
---第1轮第1次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第2次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第3次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第4次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第5次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第6次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第7次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第8次-----
1 2 3 4 5 6 7 8 9 0
---第1轮第9次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第1次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第2次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第3次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第4次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第5次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第6次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第7次-----
1 2 3 4 5 6 7 8 0 9
---第2轮第8次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第1次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第2次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第3次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第4次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第5次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第6次-----
1 2 3 4 5 6 7 0 8 9
---第3轮第7次-----
1 2 3 4 5 6 0 7 8 9
---第4轮第1次-----
1 2 3 4 5 6 0 7 8 9
---第4轮第2次-----
1 2 3 4 5 6 0 7 8 9
---第4轮第3次-----
1 2 3 4 5 6 0 7 8 9
---第4轮第4次-----
1 2 3 4 5 6 0 7 8 9
---第4轮第5次-----
1 2 3 4 5 6 0 7 8 9
---第4轮第6次-----
1 2 3 4 5 0 6 7 8 9
---第5轮第1次-----
1 2 3 4 5 0 6 7 8 9
---第5轮第2次-----
1 2 3 4 5 0 6 7 8 9
---第5轮第3次-----
1 2 3 4 5 0 6 7 8 9
---第5轮第4次-----
1 2 3 4 5 0 6 7 8 9
---第5轮第5次-----
1 2 3 4 0 5 6 7 8 9
---第6轮第1次-----
1 2 3 4 0 5 6 7 8 9
---第6轮第2次-----
1 2 3 4 0 5 6 7 8 9
---第6轮第3次-----
1 2 3 4 0 5 6 7 8 9
---第6轮第4次-----
1 2 3 0 4 5 6 7 8 9
---第7轮第1次-----
1 2 3 0 4 5 6 7 8 9
---第7轮第2次-----
1 2 3 0 4 5 6 7 8 9
---第7轮第3次-----
1 2 0 3 4 5 6 7 8 9
---第8轮第1次-----
1 2 0 3 4 5 6 7 8 9
---第8轮第2次-----
1 0 2 3 4 5 6 7 8 9
---第9轮第1次-----
0 1 2 3 4 5 6 7 8 9
---
after sort:
0 1 2 3 4 5 6 7 8 9
Process finished with exit code 0

 

Step02:选择排序

原理:每一趟从待排序的记录中选出最小的元素,放到一端。

思路:第一次从记录中选择最小的数放到一端,第二次动剩下的记录中选择最小的,放到第二位

依次往下,直到全部排序完成。

public class Sort02_SelectionSort {

    public static void main(String[] args) {
int[] arr = {4,13,2,1};
System.out.println("\n" + arr.length);
System.out.println("交换之前:");
for (int num : arr) {
System.out.print(num + " ");
}
//选择排序
for (int i = 0; i < arr.length - 1; i++) {
int k = i;
for (int j = k + 1; j < arr.length; j++) {
if (arr[j] < arr[k]) {
k = j; //记下目前找到的最小值所在的位置
}
}
//在内层循环结束,也就是找到本轮循环的最小的数以后,再进行交换
if (i != k) { //交换a[i]和a[k]
int temp = arr[i];
arr[i] = arr[k];
arr[k] = temp;
}
System.out.println("\n"+"---第"+(i+1)+"轮找到最小数的位置是第"+(k+1)+"个数-----");
for (int num : arr) {
System.out.print(num + " ");
} }
System.out.println();
System.out.println("交换后:");
for (int num : arr) {
System.out.print(num + " ");
} } }

  

查看具体执行过程

"C:\Program Files\Java\jdk1.8.0_161\bin\java" "-javaagent:C:\Program Files\JetBrains\IntelliJ IDEA 2018.1\lib\idea_rt.jar=57407:C:\Program Files\JetBrains\IntelliJ IDEA 2018.1\bin" -Dfile.encoding=UTF-8 -classpath "C:\Program Files\Java\jdk1.8.0_161\jre\lib\charsets.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\deploy.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\access-bridge-64.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\cldrdata.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\dnsns.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\jaccess.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\jfxrt.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\localedata.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\nashorn.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunec.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunjce_provider.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunmscapi.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\sunpkcs11.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\ext\zipfs.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\javaws.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jce.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jfr.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jfxswt.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\jsse.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\management-agent.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\plugin.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\resources.jar;C:\Program Files\Java\jdk1.8.0_161\jre\lib\rt.jar;D:\00M_IDEA_Project\mavenDemo_idea01\target\classes" Sort02_SelectionSort

4
交换之前:
4 13 2 1
---第1轮找到最小数的位置是第4个数-----
1 13 2 4
---第2轮找到最小数的位置是第3个数-----
1 2 13 4
---第3轮找到最小数的位置是第4个数-----
1 2 4 13
交换后:
1 2 4 13
Process finished with exit code 0

 

Step03:直接插入排序

直接插入排序是将未排序的数据插入至已排好序序列的合适位置。

思路:具体流程如下:
  1、首先比较数组的前两个数据,并排序;
  2、比较第三个元素与前两个排好序的数据,并将第三个元素放入适当的位置;
  3、比较第四个元素与前三个排好序的数据,并将第四个元素放入适当的位置;
   ......
  4、直至把最后一个元素放入适当的位置。
import java.util.Arrays;

public class Sort03_InsertSort {

    public static void main(String[] args) {
int[] arr = {4, 13, 2, 1};
System.out.println("\n" + arr.length);
System.out.println("交换之前:");
for (int num : arr) {
System.out.print(num + " ");
}
System.out.println("\n");
int tmp;
for (int i = 1; i < arr.length; i++) {
// 待插入数据
tmp = arr[i];
int j;
for (j = i - 1; j >= 0; j--) {
// 判断是否大于tmp,大于则后移一位
if (arr[j] > tmp) {
arr[j + 1] = arr[j];
} else {
break;
}
}
arr[j + 1] = tmp;
System.out.println(i + ":" + Arrays.toString(arr));
} }
}

  

private void quickSort(int[] arr, int low, int high) {
int i,j,temp,t;
if(low>high){
return;
}
i=low;
j=high;
//temp就是基准位
temp = arr[low]; while (i<j) {
//先看右边,依次往左递减
while (temp<=arr[j]&&i<j) {
j--;
}
//再看左边,依次往右递增
while (temp>=arr[i]&&i<j) {
i++;
}
//如果满足条件则交换
if (i<j) {
t = arr[j];
arr[j] = arr[i];
arr[i] = t;
} }
//最后将基准为与i和j相等位置的数字交换
arr[low] = arr[i];
arr[i] = temp;
//递归调用左半数组
quickSort(arr, low, j-1);
//递归调用右半数组
quickSort(arr, j+1, high);
}

快速排序

import java.util.Arrays;

/**
* 快速排序的测试
*
*/
public class TestSort { public int[] arr = new int[] { 7, 2, 4, 6, 0, 0, 0, 1, 6 }; public int[] sort2(int[] datas, int low, int high) {
int i = low, j = high, key = datas[low], tmp;
while (i < j) {
while (i < j && datas[j] >= key) {
j--;
}
while (i < j && datas[i] < key) {
i++;
}
if (i < j) {
tmp = datas[i];
datas[i] = datas[j];
datas[j] = tmp;
}
}
if (i - low > 0) {
sort2(datas, low, i);
}
if (high - i > 1) {
sort2(datas, i + 1, high);
}
return datas;
} /**
* 测试主方法
*
* @param args
*/
public static void main(String args[]) {
TestSort q = new TestSort();
int[] t = q.arr;
q.sort2(t, 0, t.length - 1);
System.out.println(Arrays.toString(t));
}
}

  

  

Java 中常见的各种排序算法汇总的更多相关文章

  1. Java常用的7大排序算法汇总

    1.插入排序算法 插入排序的基本思想是在遍历数组的过程中,假设在序号 i 之前的元素即 [0..i-1] 都已经排好序,本趟需要找到 i 对应的元素 x 的正确位置 k ,并且在寻找这个位置 k 的过 ...

  2. Java中的数据结构及排序算法

    (明天补充) 主要是3种接口:List Set Map List:ArrayList,LinkedList:顺序表ArrayList,链表LinkedList,堆栈和队列可以使用LinkedList模 ...

  3. 排序算法汇总(C/C++实现)

    前言:     本人自接触算法近2年以来,在不断学习中越多地发觉各种算法中的美妙.之所以在这方面过多的投入,主要还是基于自身对高级程序设计的热爱,对数学的沉迷.回想一下,先后也曾参加过ACM大大小小的 ...

  4. 程序兵法:Java String 源码的排序算法(一)

    摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘要,谢谢! 这是泥瓦匠的第103篇原创 <程序兵法:Java Str ...

  5. Java基础复习笔记基本排序算法

    Java基础复习笔记基本排序算法 1. 排序 排序是一个历来都是很多算法家热衷的领域,到现在还有很多数学家兼计算机专家还在研究.而排序是计算机程序开发中常用的一种操作.为何需要排序呢.我们在所有的系统 ...

  6. JavaScript 数据结构与算法之美 - 十大经典排序算法汇总(图文并茂)

    1. 前言 算法为王. 想学好前端,先练好内功,内功不行,就算招式练的再花哨,终究成不了高手:只有内功深厚者,前端之路才会走得更远. 笔者写的 JavaScript 数据结构与算法之美 系列用的语言是 ...

  7. java中常见的六种线程池详解

    之前我们介绍了线程池的四种拒绝策略,了解了线程池参数的含义,那么今天我们来聊聊Java 中常见的几种线程池,以及在jdk7 加入的 ForkJoin 新型线程池 首先我们列出Java 中的六种线程池如 ...

  8. Java中常见的5种WEB服务器介绍

    这篇文章主要介绍了Java中常见的5种WEB服务器介绍,它们分别是Tomcat.Resin.JBoss.WebSphere.WebLogic,需要的朋友可以参考下 Web服务器是运行及发布Web应用的 ...

  9. Java中常见的Exception种类

    Java中常见的Exception种类 1.ClassNotFoundException 2.IOException 3.NoSuchFieldException 4.NoSuchMethodExce ...

随机推荐

  1. Python+OpenCV图像处理(二)——打印图片属性、设置图片存储路径、电脑摄像头的调取和显示

    一. 打印图片属性.设置图片存储路径 代码如下: #打印图片的属性.保存图片位置 import cv2 as cv import numpy as np #numpy是一个开源的Python科学计算库 ...

  2. 如何用nginx在本地把9000端口转发到80端口上

    起因看到一个用java写的轻博客,于是就兴致冲冲的试用一下.由于是lnmp的环境,Nginx占用了80端口,新博客只能用其他的端口,这里选择了9000端口,本地测试没问题.总不能访问了域名然后在加上端 ...

  3. prufer编码 cayley定理

    背景(在codeforces 917D 报废后,看题解时听闻了这两个玩意儿.实际上917D与之“木有关西”,也可以认为是利用了prufer的一些思路.) 一棵标号树的Pufer编码规则如下:找到标号最 ...

  4. Docker学习笔记之保存和共享镜像

    0x00 概述 让 Docker 引以为傲的是它能够实现相比于其他虚拟化软件更快的环境迁移和部署,在这件事情上,轻量级的容器和镜像结构的设计无疑发挥了巨大的作用.通过将容器打包成镜像,再利用体积远小于 ...

  5. window apidoc的安装和使用

    apidoc是一个轻量级的在线REST接口文档生成系统,支持多种主流语言,包括Java.C.C#.PHP和Javascript等.使用者仅需要按照要求书写相关注释,就可以生成可读性好.界面美观的在线接 ...

  6. Python3 解析XML 层序遍历二叉树

    Python3 解析XML 层序遍历二叉树 keyword : python3, xml, xml.dom.minidom, 层序遍历, 层次遍历, 二叉树 part1 问题描述 面对如下 XML 文 ...

  7. QT5下的caffe项目属性

    TEMPLATE = app CONFIG += console c++11 CONFIG -= app_bundle CONFIG -= qt SOURCES += /home/aimhabo/ca ...

  8. Windows Installation

    If you're running on Windows it is good to run Jenkins as a service so it starts up automatically wi ...

  9. Linux 字符设备驱动开发基础(二)—— 编写简单 PWM 设备驱动【转】

    本文转载自:https://blog.csdn.net/zqixiao_09/article/details/50858776 版权声明:本文为博主原创文章,未经博主允许不得转载.    https: ...

  10. <Python>判断变量是否是DataFrame 或者 Series

    https://stackoverflow.com/questions/14808945/check-if-variable-is-dataframe Use the built-in isinsta ...