package com.ethjava;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Scanner;
public class test {
public static void main(String[] args) {
Integer arr[]={2,4,7,6,8,5,9,2};
//SortUtil.show(arr);
BubbleSort bubblesort = new BubbleSort();
bubblesort.bubblesort(arr,arr.length);
//SortUtil.show(arr);
for(int i=0;i<arr.length;i++) {
System.out.println(arr[i]);
}
}
}
class BubbleSort{
void bubblesort(Integer[] arr,int n){
if(n<=1) return;
for(int i=0;i<n;i++){
boolean flag=false;//提前退出冒泡循环的标志位,即一次比较中没有交换任何元素,这个数组就已经是有序的了
for(int j=0; j<n-i-1;j++)
//数组下标又是从0开始,i下标后面已经排序的个数就得多减1,总结就是i增加多少,j的循环位置就得减少多少
if(arr[j]>arr[j+1]){
int tem=arr[j];
arr[j]=arr[j+1];
arr[j+1]=tem;
flag=true;
}
if(!flag)
break;//没有数据交换,数组已经有序,退出排序
}
}
}
冒泡排序
最新推荐文章于 2024-08-15 09:00:00 发布
300

被折叠的 条评论
为什么被折叠?



