算法导论第三版思考题8-4

本文介绍了一种改进的快速排序算法实现,该算法通过比较关键字并对两个数组进行同步排序,适用于需要同时保持两个数组元素相对顺序一致的场景。文中提供了详细的伪代码及Python实现,并展示了排序过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

QUICK-SORT-8-4(C,key,l,r)
	j = l-1
	for i = l to r
		if COMPARE(C[i],key) =< 0
			j = j+1
			swap(C[i], C[j])
			if COMPARE(C[i],key) == 0
				k = j
	swap(C[j], C[k])
	return j
SORT-PROBLEM-8-4(A,B,l,r)
	if l < r
		p = QUICK-SORT-8-4(A,B[r],l,r)
		p = QUICK-SORT-8-4(B,A[p],l,r)
		SORT-PROBLEM-8-4(A, B, l, p-1)
		SORT-PROBLEM-8-4(A, B, p+1, r)

  

import random

def COMPARE(a, b):
    return (a - b)

def QUICK_SORT_8_4(C, key, l, r):
    j = l-1
    k = l
    for i in range(l, r + 1):
        if COMPARE(C[i], key) <= 0:
            j = j + 1
            temp = C[i]
            C[i] = C[j]
            C[j] = temp
            if COMPARE(temp, key) == 0:
                k = j
    temp = C[j]
    C[j] = C[k]
    C[k] = temp
    return j

def SORT_PROBLEM_8_4(A, B, l, r):
    if l < r:
        p = QUICK_SORT_8_4(A, B[r], l, r)
        p = QUICK_SORT_8_4(B, A[p], l, r)
        SORT_PROBLEM_8_4(A, B, l, p - 1)
        SORT_PROBLEM_8_4(A, B, p+1, r)
    return


list1 = [i+1 for i in range(30)]
random.shuffle(list1)
list2 = list1.copy()
random.shuffle(list2)
print(list1)
print(list2)
SORT_PROBLEM_8_4(list1, list2, 0, len(list1)-1)
print(list1)
print(list2)

  

转载于:https://www.cnblogs.com/MrWrong/p/7130510.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值