排序

package com.kaibing.sort;

import org.junit.jupiter.api.Test;

public class UpSort {

    public int[] arr = {1, 3, 2, 7, 5};

    /**
     * 冒泡排序:思想每次把目标(最大或最小)移到末尾
     * 时间:平均=O(n^2) | 最坏=O(n^2)  |最好=O(N)
     * 空间:O(1)
     * 稳定性:稳定
     */
    @Test
    public void testFast() {//冒泡排序
//        从小到大
        for (int i = 0; i < arr.length; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] > arr[j]) {
                    int temp = arr[i];
                    arr[i] = arr[j];
                    arr[j] = temp;
                }
            }
        }

        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }

        System.out.println("================");
//        从大到小
        for (int i = 0; i < arr.length; i++) {
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[i] < arr[j]) {
                    int temp = arr[i];
                    arr[i] = arr[j];
                    arr[j] = temp;
                }
            }
        }

        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }


    /**
     * 插入排序:把第i为的数与前面的相比较,找到合适的位置插入,并把要出入位置之后的数字都向后移
     * 时间:平均=O(n^2) | 最坏=O(n^2) | 最好O(n)
     * 空间:O(1)
     * 稳定性:稳定
     */
    @Test
    public void insertSort() {
        for (int i = 1; i < arr.length; i++) {
            int j = 0;//记录位置
            int temp = arr[i];//保存要插入的数据
            for (j = i - 1; j >= 0; j--) {
                //因为前面的i为都已经时排好序的
                if (temp < arr[j]) {
                    arr[j + 1] = arr[j];
                } else {
                    break;
                }
            }
            arr[j + 1] = temp;
        }

        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }

    }


    /**
     * 快速排序:找基准点=把数组分成两块,找到基准点的位置,分成左右两个,递归
     * 时间:平均=O(Nlog2N) | 最坏=O(N2) | 最好O(Nlog2N)
     * 空间:O(Nlog2N)
     * 稳定性:不稳定
     */
    @Test
    public void quickSort() {
        quickSortBody(0, arr.length - 1, arr);

        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i] + "===" + arr.length);

        }
    }

    public void quickSortBody(int start, int end, int[] arr) {
        if (start >= end) {
            return;
        }
        //选择基准点
        int temp = arr[start];
        int startIndex = start;
        int endIndex = end;

        while (start < end) {

            while (start < end) {
                if (arr[end] < temp) {
                    break;
                }
                end--;
            }

            while (start < end) {
                if (arr[start] > temp) {
                    break;
                }
                start++;
            }

            if (start < end) {
                int tem = arr[start];
                arr[start] = arr[end];
                arr[end] = tem;
            }
        }

        if (start == end) {
            int tem = arr[startIndex];
            arr[startIndex] = arr[end];
            arr[end] = tem;
        }
        if (start == end && end < arr.length - 2) {
            quickSortBody(startIndex, end - 1, arr);
            quickSortBody(end + 1, endIndex, arr);
        }
    }
}

 

posted @ 2018-06-29 11:20  楷兵  阅读(108)  评论(0编辑  收藏  举报