加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

golang快速排序算法

发布时间:2020-12-16 18:48:26 所属栏目:大数据 来源:网络整理
导读:go语言真的是很简洁,下面用它来实现快速排序算法 packageqsortfuncquickSort(values[]int,leftint,rightint){ifleftright{//设置基准值temp:=values[left]//设置哨兵i,j:=left,rightfor{//从右向左找,找到第一个比基准值小的数forvalues[j]=tempij{j--}//

go语言真的是很简洁,下面用它来实现快速排序算法

packageqsort

funcquickSort(values[]int,leftint,rightint){
	ifleft<right{

		//设置基准值
		temp:=values[left]

		//设置哨兵
		i,j:=left,right
		for{
			//从右向左找,找到第一个比基准值小的数
			forvalues[j]>=temp&&i<j{
				j--
			}

			//从左向右找,找到第一个比基准值大的数
			forvalues[i]<=temp&&i<j{
				i++
			}

			//如果哨兵相遇,则退出循环
			ifi>=j{
				break
			}

			//交换左右两侧的值
			values[i],values[j]=values[j],values[i]
		}

		//将基准值移到哨兵相遇点
		values[left]=values[i]
		values[i]=temp

		//递归,左右两侧分别排序
		quickSort(values,left,i-1)
		quickSort(values,i+1,right)
	}
}

funcQuickSort(values[]int){
	quickSort(values,len(values)-1)
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读