首页 > 编程语言 > 详细

常见排序算法小结

时间:2017-04-22 17:17:40      阅读:158      评论:0      收藏:0      [点我收藏+]

排序算法有很多种,包括冒泡排序,选择排序,快速排序,插入排序,希尔排序,堆排序等。这里着重讨论下冒泡排序,快速排序和插入排序这三种排序算法。

冒泡排序——时间复杂度O ( n2 )

冒泡排序从第一个元素开始,依次与后面的元素比较,每次遇到比当前元素更大(或更小)的值时,则交换数值。每一轮比较后位于当前位置的数值都是最小(或最大)的,总共需要(n-1) + (n-2) + (n-3) + …… + 1 即(n+1)*n/2次比较,时间复杂度为O(n2)。

Java实现代码为:

	public static void bubbleSort(int[] nums){
		for(int i=0;i<nums.length;i++){
			for(int j=i;j<nums.length;j++)
				if(nums[i]>nums[j]){
					int temp = nums[i];
					nums[i] = nums[j];
					nums[j] = temp;
			    }
		}
		for(int i=0;i<nums.length;i++){
			System.out.println(nums[i]);
		}
	}

  

 

常见排序算法小结

原文:http://www.cnblogs.com/lishenghua/p/6748202.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!