数组排序---冒泡排序

* 数组排序—冒泡排序

  • 比较相邻的两个数,若按照顺序排序,前面的数大于后面的数,则交换位置,第一轮过后最大的排在数组的最后面,经过n-1轮,完成排序

1.原理:比较两个相邻的元素,将值大的元素交换到右边

2.思路:依次比较相邻的两个数,将比较小的数放在前面,比较大的数放在后面。

(1)第一次比较:首先比较第一和第二个数,将小数放在前面,将大数放在后面。

(2)比较第2和第3个数,将小数 放在前面,大数放在后面。

(3)如此继续,知道比较到最后的两个数,将小数放在前面,大数放在后面,重复步骤,直至全部排序完成

(4)在上面一趟比较完成后,最后一个数一定是数组中最大的一个数,所以在比较第二趟的时候,最后一个数是不参加比较的。

(5)在第二趟比较完成后,倒数第二个数也一定是数组中倒数第二大数,所以在第三趟的比较中,最后两个数是不参与比较的。

(6)依次类推,每一趟比较次数减少依次


		/*
		 * 数组的排序:升序与降序,必须能够比较大小  数值型   字符(ASCII码值表)
		 */
		int as[] = {5,4,3,2,1};
		//升序    小到大
		for (int i = 0; i < as.length-1; i++) {//比较多少轮
			for (int j = 0; j < as.length-1-i; j++) {//比较每一轮的两个数
				int a = as[j];	//数组第一数
				int b = as[j+1];//第二个数
				//交换位置
				if(a>b){
					int temp = as[j];
					as[j]=as[j+1];
					as[j+1] = temp;
					
				}
				//用加减法
//				if(a>b){
//					as[j]=as[j]+as[j+1];
//					as[j+1]=as[j]-as[j+1];
//					as[j]=as[j]-as[j+1];
//				}
			}
			
		}
		System.out.println(Arrays.toString(as));

在这里插入图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章