wKiom1d5wEWQgnfPAAB0D9rRt4s611.png

算法稳定性

冒泡排序就是把小的元素往前调或者把大的元素往后调。比较是相邻的两个元素比较,交换也发生在这两个元素之间。所以,如果两个元素相等,我想你是不会再无聊地把他们俩交换一下的;如果两个相等的元素没有相邻,那么即使通过前面的两两交换把两个相邻起来,这时候也不会交换,所以相同元素的前后顺序并没有改变,所以冒泡排序是一种稳定排序算法。从大到小的冒泡排序

package structsmethod;
/*
 * 冒泡
 */
public class BubbleSort {
	public void bubble(int a[]){
		for(int i=0;i<a.length-1;i++){
			for(int j=0;j<a.length-i-1;j++){
				if(a[j]<a[j+1]){
					int temp=a[j];
					a[j]=a[j+1];
					a[j+1]=temp;
				}
			}
		}
	}
	public void printarr(int a[]){
		for(int i=0;i<a.length;i++){
			System.out.print(a[i]+" ");
			}
	}
	public static void main(String[] args) {
		int[] a={23,56,22,1,45,343,12};
		BubbleSort bs=new BubbleSort();
		bs.bubble(a);
		bs.printarr(a);
		
	}
}