zoukankan      html  css  js  c++  java
  • 排序

    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);
            }
        }
    }
  • 相关阅读:
    pycharm使用常见设置
    LeetCode OJ:Insertion Sort List (插入排序链表)
    LeetCode OJ:Reverse Linked List (反转链表)
    Foundations of Qt Development 学习笔记 Part1 Tips1-50
    TCPL学习毕节:第六章hash表
    TCPL学习笔记:4-12以及4-13。关于使用递归的问题。
    几种常见排序算法的C++描述
    一些灵巧的求并算法
    vs中: 错误,未定义的标识符getline 的解决方法
    QT中给程序加上主界面的图标
  • 原文地址:https://www.cnblogs.com/kaibing/p/9242520.html
Copyright © 2011-2022 走看看