冒泡排序

本文深入讲解了冒泡排序算法的实现原理及过程,通过详细步骤和代码示例,展示了如何通过双层循环比较并交换数组元素,实现从小到大的排序。以具体数组为例,逐步解析每趟排序的变化,帮助理解冒泡排序的运作机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

j和i的控制循环

在这里插入图片描述

package day03;

public class Demo02 {
	public static void main(String[] args) {
		//冒泡排序 
	/**
		 * 原理:比较两个相邻的元素,将值大的元素交换至右端。
		  思路:依次比较相邻的两个数,将小数放在前面,大数放在后面。即在第一趟:
		  首先比较第1个和第2个数,将小数放前,大数放后。然后比较第2个数和第3个数,将小数放前,大数放后,
		  如此继续,直至比较最后两个数,将小数放前,大数放后。重复第一趟步骤,直至全部排序完成。
		  举例说明:要排序数组:int[] arr={6,3,8,2,9,1};   

      第一趟排序:0

    第一次排序:6和3比较,6大于3,交换位置:  3  6  8  2  9  1

    第二次排序:6和8比较,6小于8,不交换位置:3  6  8  2  9  1

    第三次排序:8和2比较,8大于2,交换位置:  3  6  2  8  9  1

    第四次排序:8和9比较,8小于9,不交换位置:3  6  2  8  9  1

    第五次排序:9和1比较:9大于1,交换位置:  3  6  2  8  1  9

    第一趟总共进行了5次比较, 排序结果:      3  6  2  8  1  9                      arr.length-1

---------------------------------------------------------------------

第二趟排序:1

    第一次排序:3和6比较,3小于6,不交换位置:3  6  2  8  1  9

    第二次排序:6和2比较,6大于2,交换位置:  3  2  6  8  1  9

    第三次排序:6和8比较,6大于8,不交换位置:3  2  6  8  1  9

    第四次排序:8和1比较,8大于1,交换位置:  3  2  6  1  8  9

    第二趟总共进行了4次比较, 排序结果:      3  2  6  1  8  9                         arr.length-1-1

---------------------------------------------------------------------

第三趟排序:2

    第一次排序:3和2比较,3大于2,交换位置:  2  3  6  1  8  9

    第二次排序:3和6比较,3小于6,不交换位置:2  3  6  1  8  9

    第三次排序:6和1比较,6大于1,交换位置:  2  3  1  6  8  9

    第二趟总共进行了3次比较, 排序结果:      2  3  1  6  8  9                         arr.length-1-2

---------------------------------------------------------------------

第四趟排序:

    第一次排序:2和3比较,2小于3,不交换位置:2  3  1  6  8  9

    第二次排序:3和1比较,3大于1,交换位置:  2  1  3  6  8  9

    第二趟总共进行了2次比较, 排序结果:      2  1  3  6  8  9                             arr.length-1-3

---------------------------------------------------------------------

第五趟排序:            

    第一次排序:2和1比较,2大于1,交换位置:  1  2  3  6  8  9

    第二趟总共进行了1次比较, 排序结果:  1  2  3  6  8  9
                                                       arr.length-1-4
---------------------------------------------------------------------

最终结果:1  2  3  6  8  9

		*/
	
		int temp =0;
		int[] arr={6,3,8,2,9,1,10,11,4,99}; //6个长度的一维数组
		for(int i=0;i<arr.length-1;i++) { //决定排序的次数 5次
			for(int j=0;j<arr.length-1-i;j++) {
				if(arr[j]>arr[j+1]) {
					temp = arr[j];
					arr[j]=arr[j+1];
					arr[j+1]=temp;
				}
			}
		}
		for(int a:arr) {
			System.out.print(a+" ");
			
		}
//		Demo03.getSum(a, b);
		
//		int[] arr = {9,3,8,5,7,2,1};
//		int temp =0;
//		for(int i=0;i<arr.length-1;i++) { //控制循环的次数
//			for(int j =0;j<arr.length-i-1;j++) {
//				if(arr[j]>arr[j+1]) {
//					temp =arr[j];
//					arr[j]=arr[j+1];
//					arr[j+1]=temp;
//				}
//			}
//		}
//		for (int i : arr) {
//			System.out.println(i);
//		}
	}
	
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值