网站如何备案工信局,企业营销推广策划,没有经验,wordpress如何添加商桥转自#xff1a;https://www.cnblogs.com/AlwinXu/p/5424905.html 快速排序#xff08;quickSort#xff09; 快排的思想#xff1a;首先任意选取一个数据#xff08;通常选用数组的第一个数#xff09;作为关键数据#xff0c;然后将所有比它小的数都放到它前面#x…转自https://www.cnblogs.com/AlwinXu/p/5424905.html 快速排序quickSort 快排的思想首先任意选取一个数据通常选用数组的第一个数作为关键数据然后将所有比它小的数都放到它前面所有比它大的数都放到它后面这个过程称为一趟快速排序。 百度百科给的算法 一趟快速排序的算法是 1设置两个变量i、j排序开始的时候i0jN-1 2以第一个数组元素作为关键数据赋值给key即keyA[0] 3从j开始向前搜索即由后开始向前搜索(j--)找到第一个小于key的值A[j]将A[j]和A[i]互换 4从i开始向后搜索即由前开始向后搜索(i)找到第一个大于key的A[i]将A[i]和A[j]互换 5重复第3、4步直到ij (3,4步中没找到符合条件的值即3中A[j]不小于key,4中A[i]不大于key的时候改变j、i的值使得jj-1ii1直至找到为止。找到符合条件的值进行交换的时候i j指针位置不变。另外ij这一过程一定正好是i或j-完成的时候此时令循环结束。 时间复杂度O(nlgn) #QuickSort by Alvindef QuickSort(myList,start,end):#判断low是否小于high,如果为false,直接返回 if start end: i,j start,end #设置基准数 base myList[i] while i j: #如果列表后边的数,比基准数大或相等,则前移一位直到有比基准数小的数出现 while (i j) and (myList[j] base): j j - 1 #如找到,则把第j个元素赋值给第个元素i,此时表中i,j个元素相等 myList[i] myList[j] #同样的方式比较前半区 while (i j) and (myList[i] base): i i 1 myList[j] myList[i] #做完第一轮比较之后,列表被分成了两个半区,并且ij,需要将这个数设置回base myList[i] base #递归前后半区 QuickSort(myList, start, i - 1) QuickSort(myList, j 1, end) return myList myList [49,38,65,97,76,13,27,49] print(Quick Sort: ) QuickSort(myList,0,len(myList)-1) print(myList)转载于:https://www.cnblogs.com/fengff/p/9213738.html