算导--7-2-b.构造新的PARTITION'(A, p, r)

来源:互联网 发布:qq飞车黄金米格数据 编辑:程序博客网 时间:2024/05/17 22:28

修改PARTITION(A, p, r)来构造一个新的PARTITION'(A, p, r),他排列A[p..r]的元素,返回值是两个数组下标q和t,其中,p<=q<=t<=r,且有A[p..q-1]的中的元素都小于A[q],A[q..t]的元素都相等,A[t+1..r]的中的元素都大于A[q]。

时间复杂度是O(r-p)。

伪代码如下:


主要思想:若A[j]比A[p]小,则把目前标识与A[p]相等的值的最大下标加一处的值(第一个大于A[p]的值)放到原来A[j],目前标识与A[p]相等的值的最小下标的值(即第一个等于A[p]的值)放到目前标识与A[p]相等的值的最大下标加一处,然后把原来A[j]的值放到原来A[i]处,i和h一起向右移动;若A[j]和A[p]一样大,则目前标识与A[p]相等的值的最大下标加一处的值(第一个大于A[p]的值)与A[j]交换,h后移一位;若A[j]比A[p]大,把j后移一位。


0 0
原创粉丝点击