8大排序算法java实现

快速排序:
在这里插入图片描述

import java.util.Arrays;

public class QuickSort {
	public static void quickSort(int[] arr, int start, int end) {
		if (start < end) {
			// 把数组中的第0个数字作为标准数
			int sd = arr[start];
			// 记录需要排序的下标
			int low = start;
			int high = end;
			// 循环找比标准数大的数和比标准数小的数
			while (low < high) {
				while (low < high && sd <= arr[high]) {
					high--;
				}
				// 使用右边的数字替换左边的数
				arr[low] = arr[high];
				// 如果左边的数字比标准数小
				while (low < high && arr[low] <= sd) {
					low++;
				}
				arr[high] = arr[low];
			}
			// 把标准数赋给低所在的位置的元素
			arr[low] = sd;
			// 处理所有小的数字
			quickSort(arr, start, low);
			// 处理所有大的数字
			quickSort(arr, low + 1, end);
		}
	}

	public static void main(String[] args) {
		int[] arr = new int[] { 3, 4, 6, 7, 2, 7, 2, 8, 0 };
		quickSort(arr, 0, arr.length - 1);
		System.out.println(Arrays.toString(arr));
	}
}

2.插入排序

动画演示

public static void insertSort(int[] arr) {
		//遍历所有数字
		for(int i=1;i<arr.length;i++) {
			//如果当前数字比前一个数字小
			if(arr[i]<arr[i-1]) {
				//把当前遍历的数字存起来
				int j;
				int temp = arr[i];
				//遍历当前数字前面所有的数字
				for (j = i - 1; j >= 0 && arr[j] > temp; j--) {
					//把前一个数字赋给后一个数字
					arr[j + 1] = arr[j];
				}
				//把临时变量(外层for循环的当前元素)赋给不满足条件的后一个元素
				arr[j + 1] = temp;
			}		
		}
	}

猜你喜欢

转载自blog.csdn.net/hnu_zzt/article/details/90757768
今日推荐