冒泡排序

雨燕双飞 提交于 2019-12-05 04:37:20

基础排序参考
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) 是稳定的

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!