首页 > 其他分享 >冒泡排序

冒泡排序

时间:2022-11-04 14:24:19浏览次数:44  
标签:arr int 冒泡排序 array 排序 public

冒泡排序:

  1. 比较数组中,两个相邻的元素,如果第一个比第二个数大,我们就交换他们的位置
  2. 每一次比较,都会产生出一个最大或者最小的数字
  3. 下一轮则可以少一次排序
  4. 依次循环,直到结束

冒泡排序的时间复杂度为O(n2)

public class Bubble {
    public static void main(String[] args) {

        int[] arr={1,21,2,5,12,256,22,484521,2,1,2,45,4,3};
        int[] b=sort(arr);//调用完我们自己写的排序方法以后,返回一个排序后的数组
        System.out.println(Arrays.toString(b));
        
        /* for (int i:b) {
            System.out.print(i+" ");

        }*/
    }

    //法一:
    public static int[] sort(int[] array){
        //临时变量
        int temp=0;

        //外层循环,判断我们要走多少次
        for (int i = 0; i < array.length-1; i++) {
            //内层循环,比较判断两个数,如果第一个数比第二个数大,则交换位置
            for(int j=0;j<array.length-1-i;j++){
                if(array[j+1]<array[j]){
                    temp=array[j];
                    array[j]=array[j+1];
                    array[j+1]=temp;

                }
            }

        }
        return array;
    }


    //法二:
    public static int[] bubble(int[] a){
        for (int i = 0; i <a.length ; i++) {
            for (int j=i+1;j<a.length;j++){
                if(a[j]<a[i]){
                    int t=a[j];
                    a[j]=a[i];
                    a[i]=t;
                }
            }

        }
        return a;

    }
}

标签:arr,int,冒泡排序,array,排序,public
From: https://www.cnblogs.com/Ginger54/p/16857614.html

相关文章