<返回更多

冒泡算法和选择排序简单demo

2019-09-05    
加入收藏

写一个算法对1,8,5,2,4,9,7进行顺序排列并给出所使用的算法,并简述算法实现原理及时间复杂度

冒泡排序

原理:第一趟在序列(A[0]~A[n-1])中从前往后进行两个相邻元素的比较,若后者小,则交换,比较 n-1 次;第一趟排序结束,最大元素被交换到A[n-1]中,下一趟排序只需要在子序列(A[0]~A[n-2])中进行;冒泡排序最多进行 n-1 趟。基本的冒泡排序可以利用旗标的方式稍微减少一些比较的时间,当寻访完序列后都沒有发生任何的交换动作,表示排序已经完成,而无需再进行之后的比较与交换动作。

public class OrderbyArray {
	//冒泡排序 Bubble Sort 最简单的排序方法是冒泡排序方法
 public int[] orderArray(int[] array){
 	for(int i=0;i<array.length;i++){
 		for(int j=i;j<array.length;j++){
 			if(array[i]>array[j]){
 				int s = array[i];
 				array[i] = array[j];
 				array[j] = s;
 			}
 		}
 	}
 	return array;
 }
	public static void main(String[] args) {
		int [] array = {1,8,5,2,4,9,7};
		OrderbyArray order = new OrderbyArray();
		array = order.orderArray(array); 
	}
}
冒泡算法和选择排序简单demo

 

选择排序

原理:将初始序列(A[0]~A[n-1])作为待排序序列,第一趟在待排序序列(A[0]~A[n-1])中找到最小值元素,将其与第一个元素A[0]交换,这样子序列(A[0])已经有序,下一趟在排序在待排序子序列(A[1]~A[n-1])中进行。第i趟排序在待排序子序列(A[i-1]~A[n-1])中找到最小值元素,与该子序列中第一个元素A[i-1]交换。经过 n-1 趟排序后使得初始序列有序。

冒泡和选择都为 O(n2)

public class SelectSort {
 public static void main(String[] args) {
 //模拟数据
 int[] array = {1,8,5,2,4,9,7};
 System.out.println("原数组:");
 for (int i : array) {
 System.out.print(i+" ");
 }
 System.out.println();
 selectSort(array);
 System.out.println("排序后:");
 for (int i : array) {
 System.out.print(i+" ");
 }
 }
 
 public static void selectSort(int[] arr){
 for(int i = 0; i < arr.length-1; i++){
 int min = i;
 for(int j = i+1; j <arr.length-1;j++){
 if(arr[j]<arr[min]){
 min = j;
 }
 }
 if(min!=i){
 swap(arr, i, min);
 }
 }
 }
 //完成数组两元素间交换
 public static void swap(int[] arr,int a,int b){
 int temp = arr[a];
 arr[a] = arr[b];
 arr[b] = temp;
 }
}
声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多资讯 >>>