算法导论习题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)
# -*- 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)
相关文章推荐
- Python动态类型的学习---引用的理解
- Python3写爬虫(四)多线程实现数据爬取
- 垃圾邮件过滤器 python简单实现
- 下载并遍历 names.txt 文件,输出长度最长的回文人名。
- install and upgrade scrapy
- Scrapy的架构介绍
- Centos6 编译安装Python
- 使用Python生成Excel格式的图片
- 让Python文件也可以当bat文件运行
- [Python]推算数独
- Python中zip()函数用法举例
- Python中map()函数浅析
- Python将excel导入到mysql中
- Python在CAM软件Genesis2000中的应用
- 使用Shiboken为C++和Qt库创建Python绑定
- FREEBASIC 编译可被python调用的dll函数示例
- Python 七步捉虫法