Clasificación de la matriz (clasificación de burbujas)

Ordenamiento de burbuja:

1) Comparar elementos adyacentes e intercambiar si se viola el último criterio ascendente.

2) Puede simplificarse y entenderse como:

第一次,找到所有元素中最大的放在最后一个位置,不再变动
第二次,找到剩余所有元素中最大的放在倒数第二位上,不再变动
以此类推,直到只剩一个元素时不再比较

3) El método de "hundimiento" o "flotación" se puede utilizar como comparación.

Análisis del proceso de clasificación:

int [] arr = {1,5,9,4}; // ascendente

Ponga 9 en arr [3] en la primera ronda

1和5比,不换,{1,5,9,4}
5和9比,不换,{1,5,9,4}
9和4比,换,{1,5,4,9}-------9到达指定位置

En la segunda ronda, pon 5 en arr [2]

1和5比,不换,{1,5,4,9}
5和4比,换,{1,4,5,9}-------5到达指定位置

En la tercera ronda, pon 4 en arr [1]

1和4比,不换,{1,4,5,9}-----4到达指定位置

Por ejemplo:

就像十个人抽10个球,到最后一个人抽的时候还用再抽么?
不用了,因为就剩下一个球了
Características:

5.1) Al comparar elementos arr.length, solo necesita comparar arr.length-1 rondas
5.2) Cada ronda de comparación comienza desde el primer elemento y se compara
cada vez con su siguiente elemento
5.3) El número que se ha ordenado es solo Ya no en comparación

Código:

	int[] bubble = new int[10];
//	给每个元素赋值1-100之间的随机数
	for(int i=0;i<bubble.length;i++){
    
    
		bubble[i] = (int)(Math.random()*100);
	}
	for(int i=0;i<bubble.length-1;i++){
    
    //控制轮数
		for(int j=0;j<bubble.length-1-i;j++){
    
    //控制对比次数
			if(bubble[j]>bubble[j+1]){
    
    //对比两个相邻的数
				int t = bubble[j];//将较大值放入空杯子
				bubble[j] = bubble[j+1];//将较小值前移
				bubble[j+1] = t;//将空杯子中的较大值后移
			}
		}
	}
//内层循环是用来控制比较次数的,那么对比次数的范围从何而来?
	i=0(1)3次
	i=1(2)2次
	i=2(3)1//从中可以发现每轮i的值和比较次数相加就是比较的轮数。
//同理比较的轮数减去i就是比较的次数了,用代码的实现:bubble.length-1-i	

Supongo que te gusta

Origin blog.csdn.net/qq_54177999/article/details/114435292
Recomendado
Clasificación