zoukankan      html  css  js  c++  java
  • 冒泡排序

    基础排序参考
    https://blog.csdn.net/yushiyi6453/article/details/76407640

    冒泡排序

    冒泡排序从小到大排序:一开始交换的区间为0~N-1
    将第1个数和第2个数进行比较,前面大于后面,交换两个数,否则不交换。再比较第2个数和第三个数,前面大于后面,交换两个数否则不交换。依次进行,最大的数会放在数组最后的位置。然后将范围变为0~N-2,数组第二大的数会放在数组倒数第二的位置。依次进行整个交换过程,最后范围只剩一个数时数组即为有序。

    package bubblesort;

    import java.util.Scanner;

    /**
     * @author WangXiaoeZhe
     * @Date: Created in 2019/11/21 16:04
     * @description:
     */

    public class BubbleSort {
        public static void main(String[] args) {
            Scanner scanner = new Scanner(System.in);
            int[] arr = new int[5];
            for (int i = 0; i < arr.length; i++) {
                arr[i] = scanner.nextInt();
            }
            int[] ints = bubbleSort(arr);
            for (int i = 0; i < ints.length; i++) {
                System.out.println(arr[i]);
            }

        }

        private static int[] bubbleSort(int[] arr) {
            for (int end = arr.length - 1; end > 0; end--) {
                for (int j = 0; j < end; j++) {
                    if (arr[j] > arr[j + 1]) {
                        swap(arr,j,j+1);
                    }
                }

            }
            return arr;
        }
        public static void swap(int[] arr, int i, int j) {
            int tmp = arr[i];
            arr[i] = arr[j];
            arr[j] = tmp;
        }
    }

    平均时间复杂度: O(n^2) 最坏时间复杂度:O(n^2) 空间复杂度: O(1) 是稳定的

  • 相关阅读:
    Flutter移动电商实战 --(40)路由_Fluro的全局注入和使用方法
    Flutter移动电商实战 --(39)路由_Fluro的路由配置和静态化
    Flutter移动电商实战 --(38)路由_Fluro中Handler编写方法
    Flutter移动电商实战 --(37)路由_Fluro引入和商品详细页建立
    网络基础:NetBIOS
    linux 定时任务
    linux useradd 命令基本用法
    Git undo 操作
    Git 查看文件的历史
    Ubuntu14.04安装postgresql9.4
  • 原文地址:https://www.cnblogs.com/wuhen8866/p/11906332.html
Copyright © 2011-2022 走看看