java 算法 6种排序小结

网友投稿 226 2022-09-21


java 算法 6种排序小结

目录冒泡排序选择排序插入排序希尔排序归并排序快速排序

冒泡排序

package 冒泡排序;

import java.util.Arrays;

public class Bubble {

/**

* 对数组a中的元素进行排序

* @param a

*/

public static int[] sort(int[] a){

for (int i=a.length-1;i>0;i--){

for (int j=0;j

if(greater(a[j],a[j+1])){

exch(a,j,j+1);

}

}

}

return a;

}

/**

* 比较v元素是否大于w元素

* @param v

* @param w

* @return

*/

private static Boolean greater(int v,int w){

if (v>=w){

return true;

}

return false;

}

/**

* fYlFJlC数据元素i和j交换位置

* @param a

* @param i

* @param j

*/

private static void exch(int[] a,int i,int j){

int t=a[i];

a[i]=a[j];

a[j]=t;

}

public static void main(String[] args) {

int[] a={4,5,6,3,2,1};

int[] sort = Bubble.sort(a);

System.out.println(Arrays.toString(sort));

}

}

选择排序

package cn.itcast.algorithm.sort;

/**

* 选择排序

*/

public class Selection {

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a){

for(int i=0;i<=a.length-2;i++){

//定义一个变量,记录最小元素所在的索引,默认为参与选择排序的第一个元素所在的位置

int minIndex = i;

for(int j=i+1;j

//需要比较最小索引minIndex处的值和j索引处的值;

if (greater(a[minIndex],a[j])){

minIndex=j;

}

}

//交换最小元素所在索引minIndex处的值和索引i处的值

exch(a,i,minIndex);

}

}

/*

比较v元素是否大于w元素

*/

private static boolean greater(Comparable v,Comparable w){

return v.compareTo(w)>0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a,int i,int j){

Comparable temp;

temp = a[i];

a[i]=a[j];

a[j]=temp;

}

}

插入排序

package 插入排序;

import java.util.Arrays;

public class Insertion {

public static void sort(int[] a){

for (int i=1;i

//当前元素为a[i],依次和i前面的元素比较,找到一个小于a[i]的元素

for (int j=i;j>0;j--){

if (greater(a[j-1],a[j])){

exch(a,j-1,j);

}else {

break;

}

}

}

}

/**

* 比较v元素是否大于w元素

* @param v

* @param w

* @return

*/

private static Boolean greater(int v,int w){

if (v>=w){

return true;

}

return false;

}

/**

* 数据元素i和j交换位置

* @param a

* @param i

* @param j

*/

private static void exch(int[] a,int i,int j){

int t=a[i];

a[i]=a[j];

a[j]=t;

}

public static void main(String[] args) {

int[] a={4,3,2,10,12,1,5,6};

Insertion.sort(a);

System.out.println(Arrays.toString(a));

}

}

希尔排序

package 希尔排序;

import java.util.Arrays;

public class Shell {

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a) {

int N = a.length;

//确定增长量h的最大值

int h = 1;

while (h < N / 2) {

h = h * 2 + 1;

}

//当增长量h小于1,排序结束

while (h >= 1) {

//找到待插入的元素

for (int i = h; i < N; i++) {

//a[i]就是待插入的元素

//把a[i]插入到a[i-h],a[i-2h],a[i-3h]...序列中

for (int j = i; j >= h; j -= h) {

//a[j]就是待插入元素,依次和a[j-h],a[j-2h],a[j-3h]进行比较,如果a[j]小,那么交换位置,如果不小于,a[j] 大,则插入完成。

if (greater(a[j - h], a[j])) {

exch(a, j, j - h);

} else {

break;

}

}

}

h /= 2;

}

}

/*

比较v元素是否大于w元素

*/

private static boolean greater(Comparable v, Comparable w) {

return v.compareTo(w) > 0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

//测试代码

public static void main(String[] args) {

Integer[] a = {9, 1, 2, 5, 7, 4, 8, 6, 3, 5};

Shell.sort(a);

System.out.println(Arrays.toString(a));

}

}

归并排序

package 归并排序;

import java.util.Arrays;

public class Merge {

private static Comparable[] assist;//归并所需要的辅助数组

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a) {

assist = new Comparable[a.length];

int lo = 0;

int hi = a.length - 1;

sort(a, lo, hi);

}

/*

对数组a中从lo到hi的元素进行排序

*/

private static void sort(Comparable[] a, int lo, int hi) {

if (hi <= lo) {

return;

}

int mid = lo + (hi - lo) / 2;

//对lo到mid之间的元素进行排序;

sort(a, lo, mid);

//对mid+1到hi之间的元素进行排序;

sort(a, mid + 1, hi);

//对lo到mid这组数据和mid到hi这组数据进行归并

merge(a, lo, mid, hi);

}

/*

对数组中,从lo到mid为一组,从mid+1到hi为一组,对这两组数据进行归并

*/

private static void merge(Comparable[] a, int lo, int mid, int hi) {

//lo到mid这组数据和mid+1到hi这组数据归并到辅助数组assist对应的索引处

int i = lo;//定义一个指针,指向assist数组中开始填充数据的索引

int p1 = lo;//定义一个指针,指向第一组数据的第一个元素

int p2 = mid + 1;//定义一个指针,指向第二组数据的第一个元素

//比较左边小组和右边小组中的元素大小,哪个小,就把哪个数据填充到assist数组中

while (p1 <= mid && p2 <= hi) {

if (less(a[p1], a[p2])) {

assist[i++] = a[p1++];

} else {

assist[i++] = a[p2++];

}

}

//上面的循环结束后,如果退出循环的条件是p1<=mid,则证明左边小组中的数据已经归并完毕,如果退

//出循环的条件是p2 <= hi, 则证明右边小组的数据已经填充完毕;

//所以需要把未填充完毕的数据继续填充到assist中,//下面两个循环,只会执行其中的一个

while (p1 <= mid) {

assist[i++] = a[p1++];

}

while (p2 <= hi) {

assist[i++] = a[p2++];

}

//到现在为止,assist数组中,从lo到hi的元素是有序的,再把数据拷贝到a数组中对应的索引处

for (int index = lo; index <= hi; index++) {

a[index] = assist[index];

}

}

/*

比较v元素是否小于w元素

*/

private static boolean less(Comparable v, Comparable w) {

return v.compareTo(w) < 0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

//测试代码

public static void main(String[] args) throws Exception {

Integer[] arr = {8, 4, 5, 7, 1, 3, 6, 2};

Merge.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

快速排序

package 快速排序;

import java.util.Arrays;

public class Quick {

public static void sort(Comparable[] a) {

int lo = 0;

int hi = a.length - 1;

sort(a, lo, hi);

}

private static void sort(Comparable[] a, int lo, int hi) {

if (hi <= lo) {

return;

}

//对a数组中,从lo到hi的元素进行切分

int partition = partition(a, lo, hi);

//对左边分组中的元素进行排序

//对右边分组中的元素进行排序

sort(a, lo, partition - 1);

sort(a, partition + 1, hi);

}

public static int partition(Comparable[] a, int lo, int hi) {

Comparable key = a[lo];//把最左边的元素当做基准值

int left = lo;//定义一个左侧指针,初始指向最左边的元素

int right = hi + 1;//定义一个右侧指针,初始指向左右侧的元素下一个位置

//进行切分

while (true) {

//先从右往左扫描,找到一个比基准值小的元素

while (less(key, a[--right])) {//循环停止,证明找到了一个比基准值小的元素

if (right == lo) {

break;//已经扫描到最左边了,无需继续扫描

}

}

//再从左往右扫描,找一个比基准值大的元素

while (less(a[++left], key)) {//循环停止,证明找到了一个比基准值大的元素

if (left == hi) {

break;//已经扫描到了最右边了,无需继续扫描

}

}

if (left >= right) {

//扫描完了所有元素,结束循环

break;

} else {

//交换left和right索引处的元素

exch(a, left, right);

}

}

//交换最后rigth索引处和基准值所在的索引处的值

exch(a, lo, right);

return right;//right就是切分的界限

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

/*

比较v元素是否小于w元素

*/

private static boolean less(Comparable v, Comparable w) {

return v.compareTo(w) < 0;

}

//测试代码

public static void main(String[] args) throws Exception {

Integer[] arr = {6, 1, 2, 7, 9, 3, 4, 5, 8};

Quick.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

//需要比较最小索引minIndex处的值和j索引处的值;

if (greater(a[minIndex],a[j])){

minIndex=j;

}

}

//交换最小元素所在索引minIndex处的值和索引i处的值

exch(a,i,minIndex);

}

}

/*

比较v元素是否大于w元素

*/

private static boolean greater(Comparable v,Comparable w){

return v.compareTo(w)>0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a,int i,int j){

Comparable temp;

temp = a[i];

a[i]=a[j];

a[j]=temp;

}

}

插入排序

package 插入排序;

import java.util.Arrays;

public class Insertion {

public static void sort(int[] a){

for (int i=1;i

//当前元素为a[i],依次和i前面的元素比较,找到一个小于a[i]的元素

for (int j=i;j>0;j--){

if (greater(a[j-1],a[j])){

exch(a,j-1,j);

}else {

break;

}

}

}

}

/**

* 比较v元素是否大于w元素

* @param v

* @param w

* @return

*/

private static Boolean greater(int v,int w){

if (v>=w){

return true;

}

return false;

}

/**

* 数据元素i和j交换位置

* @param a

* @param i

* @param j

*/

private static void exch(int[] a,int i,int j){

int t=a[i];

a[i]=a[j];

a[j]=t;

}

public static void main(String[] args) {

int[] a={4,3,2,10,12,1,5,6};

Insertion.sort(a);

System.out.println(Arrays.toString(a));

}

}

希尔排序

package 希尔排序;

import java.util.Arrays;

public class Shell {

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a) {

int N = a.length;

//确定增长量h的最大值

int h = 1;

while (h < N / 2) {

h = h * 2 + 1;

}

//当增长量h小于1,排序结束

while (h >= 1) {

//找到待插入的元素

for (int i = h; i < N; i++) {

//a[i]就是待插入的元素

//把a[i]插入到a[i-h],a[i-2h],a[i-3h]...序列中

for (int j = i; j >= h; j -= h) {

//a[j]就是待插入元素,依次和a[j-h],a[j-2h],a[j-3h]进行比较,如果a[j]小,那么交换位置,如果不小于,a[j] 大,则插入完成。

if (greater(a[j - h], a[j])) {

exch(a, j, j - h);

} else {

break;

}

}

}

h /= 2;

}

}

/*

比较v元素是否大于w元素

*/

private static boolean greater(Comparable v, Comparable w) {

return v.compareTo(w) > 0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

//测试代码

public static void main(String[] args) {

Integer[] a = {9, 1, 2, 5, 7, 4, 8, 6, 3, 5};

Shell.sort(a);

System.out.println(Arrays.toString(a));

}

}

归并排序

package 归并排序;

import java.util.Arrays;

public class Merge {

private static Comparable[] assist;//归并所需要的辅助数组

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a) {

assist = new Comparable[a.length];

int lo = 0;

int hi = a.length - 1;

sort(a, lo, hi);

}

/*

对数组a中从lo到hi的元素进行排序

*/

private static void sort(Comparable[] a, int lo, int hi) {

if (hi <= lo) {

return;

}

int mid = lo + (hi - lo) / 2;

//对lo到mid之间的元素进行排序;

sort(a, lo, mid);

//对mid+1到hi之间的元素进行排序;

sort(a, mid + 1, hi);

//对lo到mid这组数据和mid到hi这组数据进行归并

merge(a, lo, mid, hi);

}

/*

对数组中,从lo到mid为一组,从mid+1到hi为一组,对这两组数据进行归并

*/

private static void merge(Comparable[] a, int lo, int mid, int hi) {

//lo到mid这组数据和mid+1到hi这组数据归并到辅助数组assist对应的索引处

int i = lo;//定义一个指针,指向assist数组中开始填充数据的索引

int p1 = lo;//定义一个指针,指向第一组数据的第一个元素

int p2 = mid + 1;//定义一个指针,指向第二组数据的第一个元素

//比较左边小组和右边小组中的元素大小,哪个小,就把哪个数据填充到assist数组中

while (p1 <= mid && p2 <= hi) {

if (less(a[p1], a[p2])) {

assist[i++] = a[p1++];

} else {

assist[i++] = a[p2++];

}

}

//上面的循环结束后,如果退出循环的条件是p1<=mid,则证明左边小组中的数据已经归并完毕,如果退

//出循环的条件是p2 <= hi, 则证明右边小组的数据已经填充完毕;

//所以需要把未填充完毕的数据继续填充到assist中,//下面两个循环,只会执行其中的一个

while (p1 <= mid) {

assist[i++] = a[p1++];

}

while (p2 <= hi) {

assist[i++] = a[p2++];

}

//到现在为止,assist数组中,从lo到hi的元素是有序的,再把数据拷贝到a数组中对应的索引处

for (int index = lo; index <= hi; index++) {

a[index] = assist[index];

}

}

/*

比较v元素是否小于w元素

*/

private static boolean less(Comparable v, Comparable w) {

return v.compareTo(w) < 0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

//测试代码

public static void main(String[] args) throws Exception {

Integer[] arr = {8, 4, 5, 7, 1, 3, 6, 2};

Merge.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

快速排序

package 快速排序;

import java.util.Arrays;

public class Quick {

public static void sort(Comparable[] a) {

int lo = 0;

int hi = a.length - 1;

sort(a, lo, hi);

}

private static void sort(Comparable[] a, int lo, int hi) {

if (hi <= lo) {

return;

}

//对a数组中,从lo到hi的元素进行切分

int partition = partition(a, lo, hi);

//对左边分组中的元素进行排序

//对右边分组中的元素进行排序

sort(a, lo, partition - 1);

sort(a, partition + 1, hi);

}

public static int partition(Comparable[] a, int lo, int hi) {

Comparable key = a[lo];//把最左边的元素当做基准值

int left = lo;//定义一个左侧指针,初始指向最左边的元素

int right = hi + 1;//定义一个右侧指针,初始指向左右侧的元素下一个位置

//进行切分

while (true) {

//先从右往左扫描,找到一个比基准值小的元素

while (less(key, a[--right])) {//循环停止,证明找到了一个比基准值小的元素

if (right == lo) {

break;//已经扫描到最左边了,无需继续扫描

}

}

//再从左往右扫描,找一个比基准值大的元素

while (less(a[++left], key)) {//循环停止,证明找到了一个比基准值大的元素

if (left == hi) {

break;//已经扫描到了最右边了,无需继续扫描

}

}

if (left >= right) {

//扫描完了所有元素,结束循环

break;

} else {

//交换left和right索引处的元素

exch(a, left, right);

}

}

//交换最后rigth索引处和基准值所在的索引处的值

exch(a, lo, right);

return right;//right就是切分的界限

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

/*

比较v元素是否小于w元素

*/

private static boolean less(Comparable v, Comparable w) {

return v.compareTo(w) < 0;

}

//测试代码

public static void main(String[] args) throws Exception {

Integer[] arr = {6, 1, 2, 7, 9, 3, 4, 5, 8};

Quick.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

//当前元素为a[i],依次和i前面的元素比较,找到一个小于a[i]的元素

for (int j=i;j>0;j--){

if (greater(a[j-1],a[j])){

exch(a,j-1,j);

}else {

break;

}

}

}

}

/**

* 比较v元素是否大于w元素

* @param v

* @param w

* @return

*/

private static Boolean greater(int v,int w){

if (v>=w){

return true;

}

return false;

}

/**

* 数据元素i和j交换位置

* @param a

* @param i

* @param j

*/

private static void exch(int[] a,int i,int j){

int t=a[i];

a[i]=a[j];

a[j]=t;

}

public static void main(String[] args) {

int[] a={4,3,2,10,12,1,5,6};

Insertion.sort(a);

System.out.println(Arrays.toString(a));

}

}

希尔排序

package 希尔排序;

import java.util.Arrays;

public class Shell {

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a) {

int N = a.length;

//确定增长量h的最大值

int h = 1;

while (h < N / 2) {

h = h * 2 + 1;

}

//当增长量h小于1,排序结束

while (h >= 1) {

//找到待插入的元素

for (int i = h; i < N; i++) {

//a[i]就是待插入的元素

//把a[i]插入到a[i-h],a[i-2h],a[i-3h]...序列中

for (int j = i; j >= h; j -= h) {

//a[j]就是待插入元素,依次和a[j-h],a[j-2h],a[j-3h]进行比较,如果a[j]小,那么交换位置,如果不小于,a[j] 大,则插入完成。

if (greater(a[j - h], a[j])) {

exch(a, j, j - h);

} else {

break;

}

}

}

h /= 2;

}

}

/*

比较v元素是否大于w元素

*/

private static boolean greater(Comparable v, Comparable w) {

return v.compareTo(w) > 0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

//测试代码

public static void main(String[] args) {

Integer[] a = {9, 1, 2, 5, 7, 4, 8, 6, 3, 5};

Shell.sort(a);

System.out.println(Arrays.toString(a));

}

}

归并排序

package 归并排序;

import java.util.Arrays;

public class Merge {

private static Comparable[] assist;//归并所需要的辅助数组

/*

对数组a中的元素进行排序

*/

public static void sort(Comparable[] a) {

assist = new Comparable[a.length];

int lo = 0;

int hi = a.length - 1;

sort(a, lo, hi);

}

/*

对数组a中从lo到hi的元素进行排序

*/

private static void sort(Comparable[] a, int lo, int hi) {

if (hi <= lo) {

return;

}

int mid = lo + (hi - lo) / 2;

//对lo到mid之间的元素进行排序;

sort(a, lo, mid);

//对mid+1到hi之间的元素进行排序;

sort(a, mid + 1, hi);

//对lo到mid这组数据和mid到hi这组数据进行归并

merge(a, lo, mid, hi);

}

/*

对数组中,从lo到mid为一组,从mid+1到hi为一组,对这两组数据进行归并

*/

private static void merge(Comparable[] a, int lo, int mid, int hi) {

//lo到mid这组数据和mid+1到hi这组数据归并到辅助数组assist对应的索引处

int i = lo;//定义一个指针,指向assist数组中开始填充数据的索引

int p1 = lo;//定义一个指针,指向第一组数据的第一个元素

int p2 = mid + 1;//定义一个指针,指向第二组数据的第一个元素

//比较左边小组和右边小组中的元素大小,哪个小,就把哪个数据填充到assist数组中

while (p1 <= mid && p2 <= hi) {

if (less(a[p1], a[p2])) {

assist[i++] = a[p1++];

} else {

assist[i++] = a[p2++];

}

}

//上面的循环结束后,如果退出循环的条件是p1<=mid,则证明左边小组中的数据已经归并完毕,如果退

//出循环的条件是p2 <= hi, 则证明右边小组的数据已经填充完毕;

//所以需要把未填充完毕的数据继续填充到assist中,//下面两个循环,只会执行其中的一个

while (p1 <= mid) {

assist[i++] = a[p1++];

}

while (p2 <= hi) {

assist[i++] = a[p2++];

}

//到现在为止,assist数组中,从lo到hi的元素是有序的,再把数据拷贝到a数组中对应的索引处

for (int index = lo; index <= hi; index++) {

a[index] = assist[index];

}

}

/*

比较v元素是否小于w元素

*/

private static boolean less(Comparable v, Comparable w) {

return v.compareTo(w) < 0;

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

//测试代码

public static void main(String[] args) throws Exception {

Integer[] arr = {8, 4, 5, 7, 1, 3, 6, 2};

Merge.sort(arr);

System.out.println(Arrays.toString(arr));

}

}

快速排序

package 快速排序;

import java.util.Arrays;

public class Quick {

public static void sort(Comparable[] a) {

int lo = 0;

int hi = a.length - 1;

sort(a, lo, hi);

}

private static void sort(Comparable[] a, int lo, int hi) {

if (hi <= lo) {

return;

}

//对a数组中,从lo到hi的元素进行切分

int partition = partition(a, lo, hi);

//对左边分组中的元素进行排序

//对右边分组中的元素进行排序

sort(a, lo, partition - 1);

sort(a, partition + 1, hi);

}

public static int partition(Comparable[] a, int lo, int hi) {

Comparable key = a[lo];//把最左边的元素当做基准值

int left = lo;//定义一个左侧指针,初始指向最左边的元素

int right = hi + 1;//定义一个右侧指针,初始指向左右侧的元素下一个位置

//进行切分

while (true) {

//先从右往左扫描,找到一个比基准值小的元素

while (less(key, a[--right])) {//循环停止,证明找到了一个比基准值小的元素

if (right == lo) {

break;//已经扫描到最左边了,无需继续扫描

}

}

//再从左往右扫描,找一个比基准值大的元素

while (less(a[++left], key)) {//循环停止,证明找到了一个比基准值大的元素

if (left == hi) {

break;//已经扫描到了最右边了,无需继续扫描

}

}

if (left >= right) {

//扫描完了所有元素,结束循环

break;

} else {

//交换left和right索引处的元素

exch(a, left, right);

}

}

//交换最后rigth索引处和基准值所在的索引处的值

exch(a, lo, right);

return right;//right就是切分的界限

}

/*

数组元素i和j交换位置

*/

private static void exch(Comparable[] a, int i, int j) {

Comparable t = a[i];

a[i] = a[j];

a[j] = t;

}

/*

比较v元素是否小于w元素

*/

private static boolean less(Comparable v, Comparable w) {

return v.compareTo(w) < 0;

}

//测试代码

public static void main(String[] args) throws Exception {

Integer[] arr = {6, 1, 2, 7, 9, 3, 4, 5, 8};

Quick.sort(arr);

System.out.println(Arrays.toString(arr));

}

}


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:假装网络工程师21——利用MPLS解决BGP路由黑洞(bgp路由黑洞解决方法)
下一篇:TCP/IP学习之“TFTP”(TcP/IP)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~