您的位置:首页 > 编程语言 > Python开发

算法导论习题2-4 Inversions 逆序数

2016-07-25 19:17 375 查看
简单地改一下归并排序即可

# -*- coding: utf-8 -*-

def inversioncountmask(l):
l1 = l[:]
return inversionscount(l1, 0, len(l1)-1)

def inversionscount(l, p, r):
if p < r:
q = (p+r)/2
return inversionscount(l, p, q) + inversionscount(l, q+1, r) + mergecount(l, p, q, r)
else:
return 0

def mergecount(l, p, q, r):
l1 = l[p:q+1]
l2 = l[q+1:r+1]
count = 0
for x in range(p, r+1):
if (len(l1) is not 0) & (len(l2) is not 0):
if l1[0] < l2[0]:
l[x] = l1[0]
l1.pop(0)
else:
l[x] = l2[0]
l2.pop(0)
count += len(l1)
elif len(l1) is 0:
l[x] = l2[0]
l2.pop(0)
else:
l[x] = l1[0]
l1.pop(0)
return count

l = [1, 3, 5, 7, 9, 11]
l1 = [2, 3, 8, 6, 1]
print inversioncountmask(l)
print inversioncountmask(l1)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息