栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

交换排序和快速排序(交换排序算法的实现)

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

交换排序和快速排序(交换排序算法的实现)

1.1冒泡排序 1.1.1基本介绍:

冒泡排序(Bubble Sorting)的基本思想是:通过将排序序列从前向后从下标小的元素开始,依次比较相邻元素的值,若发现逆序则交换,使得值相对较大的元素逐渐从前移动到后,像是水里的泡泡一样沉得往下落,轻的向上冒。

优化:当如果其中一趟冒泡排序没有进行交换时,则说明序列有序,此时就无需在进行排序。也就是说可以在排序过程中设置一个标志flag判断元素是否进行过叫唤。从而提升排序效率。

1.1.2代码实现:
package DataStructure;

import java.util.Arrays;

public class BubbleSort {

	public static void main(String[] args) {
		int[] num = {20,9,-1,20,49};
		BubbleSort(num);
		System.out.println(Arrays.toString(num));
		
		
		

	}
	
	public static void BubbleSort(int[] array) { 
		//冒泡排序的时间复杂度一般为O(n²)
		int temp = 0;
		boolean flag = false;//标识变量 表示是否进行交换
		for(int i=0;iarray[j+1]) {
					flag = true;
					 temp=array[j];
					array[j] = array[j+1];
					array[j+1] = temp;
					
				}
			}
			if(!flag) {//该趟排序中 没有发生交换
				break;
			}else {
				flag = false;//重置flag!!! 进行下次判断
			}
	   }
	
   }
	
	
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/776800.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号