Go语言实现冒泡排序、选择排序、快速排序及插入排序的方法
本文实例讲述了Go语言实现冒泡排序、选择排序、快速排序及插入排序的方法。分享给大家供大家参考。具体分析如下:
算法是程序的灵魂,而排序算法则是一种最基本的算法。排序算法有许多种,这里介绍4中排序算法:冒泡排序,选择排序,快速排序和插入排序,以从小到大为例。
一、冒泡排序
冒泡排序的原理是,对给定的数组进行多次遍历,每次均比较相邻的两个数,如果前一个比后一个大,则交换这两个数。经过第一次遍历之后,最大的数就在最右侧了;第二次遍历之后,第二大的数就在右数第二个位置了;以此类推。
//冒泡排序(排序10000个随机整数,用时约145ms)
funcbubbleSort(nums[]int){
fori:=0;i<len(nums);i++{
forj:=1;j<len(nums)-i;j++{
ifnums[j]<nums[j-1]{
//交换
nums[j],nums[j-1]=nums[j-1],nums[j]
}
}
}
}二、选择排序
选择排序的原理是,对给定的数组进行多次遍历,每次均找出最大的一个值的索引。
//选择排序(排序10000个随机整数,用时约45ms)
funcselectSort(nums[]int){
length:=len(nums)
fori:=0;i<length;i++{
maxIndex:=0
//寻找最大的一个数,保存索引值
forj:=1;j<length-i;j++{
ifnums[j]>nums[maxIndex]{
maxIndex=j
}
}
nums[length-i-1],nums[maxIndex]=nums[maxIndex],nums[length-i-1]
}
}三、快速排序
快速排序的原理是,首先找到一个数pivot把数组‘平均'分成两组,使其中一组的所有数字均大于另一组中的数字,此时pivot在数组中的位置就是它正确的位置。然后,对这两组数组再次进行这种操作。
//快速排序(排序10000个随机整数,用时约0.9ms)
funcquickSort(nums[]int){
recursionSort(nums,0,len(nums)-1)
}
funcrecursionSort(nums[]int,leftint,rightint){
ifleft<right{
pivot:=partition(nums,left,right)
recursionSort(nums,left,pivot-1)
recursionSort(nums,pivot+1,right)
}
}
funcpartition(nums[]int,leftint,rightint)int{
forleft<right{
forleft<right&&nums[left]<=nums[right]{
right--
}
ifleft<right{
nums[left],nums[right]=nums[right],nums[left]
left++
}
forleft<right&&nums[left]<=nums[right]{
left++
}
ifleft<right{
nums[left],nums[right]=nums[right],nums[left]
right--
}
}
returnleft
}四、插入排序
插入排序的原理是,从第二个数开始向右侧遍历,每次均把该位置的元素移动至左侧,放在放在一个正确的位置(比左侧大,比右侧小)。
//插入排序(排序10000个整数,用时约30ms)
funcinsertSort(nums[]int){
fori:=1;i<len(nums);i++{
ifnums[i]<nums[i-1]{
j:=i-1
temp:=nums[i]
forj>=0&&nums[j]>temp{
nums[j+1]=nums[j]
j--
}
nums[j+1]=temp
}
}
}
通过多次测试可以发现,快速排序是效率最高的。
希望本文所述对大家的Go语言程序设计有所帮助。