• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >编程问答 > python归并排序求逆序数问题

python归并排序求逆序数问题

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-06-07

佚名通过本文主要向大家介绍了python归并排序,归并排序求逆序对,归并排序 逆序数,归并求逆序数,归并求逆序对等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com
问题:python归并排序求逆序数问题
描述:

class nx:  
    count = 0
    def __init__(self):    
        self.str_list=[]
        self.N = int(raw_input().strip())
        for _ in xrange(self.N):
            self.str_list.append(raw_input().strip())
        print self.count_inversion(self.str_list)

    def merge(self, ListA, ListB):
        self.newlist = []
        while ListA and ListB:
            if ListA[0] > ListB[0]:
               self.newlist.append(ListB[0])
               ListB = ListB[1:]
               self.count += len(ListA)
               print str(len(ListA))+'****   '
            else:
               self.newlist.append(ListA[0])
               ListA =ListA[1:]         
        if ListA:
            self.newlist = self.newlist + ListA  
        elif ListB:
            self.newlist = self.newlist + ListB        
        return self.newlist       

    def merge_sort(self, A):
        if len(A) == 1:
            return A
        else:
            self.middle = len(A)/2        
            print '**************'
            print 'Ais '+str(A)
            print 'middle is '+ str(self.middle)
            print 'zuo'
            print A[:self.middle]
            print 'you'
            print A[self.middle:]
            self.sa1 = self.merge_sort(A[:self.middle])
            self.sa2 = self.merge_sort(A[self.middle:])
            return self.merge(self.sa1, self.sa2)

    def count_inversion(self, sequence):
        self.merge_sort(sequence)
        return self.count
    if __name__ == '__main__':
        nx()

结果:


Ais ['2', '4', '3', '1']
middle is 2
zuo
['2', '4']
you
['3', '1']


Ais ['2', '4']
middle is 1
zuo
['2']
you
['4']

    ****************为什么会这样
    Ais ['4', '3', '1']
    middle is 1
    zuo
    ['4']
    you
    ['3', '1']
    ****************

Ais ['3', '1']
middle is 1
zuo
['3']
you
['1']


我知道了,python局部变量问题

class nx:
def init(self):
self.count = 0
self.str_list=[]
self.N = int(raw_input().strip())
for _ in xrange(self.N):
self.str_list.append(raw_input().strip())
print self.count_inversion(self.str_list)

def merge(self, ListA, ListB):
    newlist = []
    while ListA and ListB:
        if int(ListA[0]) > int(ListB[0]):
           self.count += len(ListA)
           newlist.append(ListB.pop(0))               
        else:
           newlist.append(ListA.pop(0)) 
    return newlist + ListA + ListB     

def merge_sort(self, A):
    if len(A) == 1: return A
    else:
        middle = len(A)/2        
        return self.merge(self.merge_sort(A[:middle]), self.merge_sort(A[middle:]))        
def count_inversion(self, sequence):
    self.merge_sort(sequence)
    return self.count

if name == 'main':
nx()



解决方案1:

就是个边界条件的问题,不等号加上或者去掉等号


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • python归并排序求逆序数问题

相关文章

  • 2017-06-07 python有什么命令可以实现弹窗,让用户选择文件?
  • 2017-06-07 香港最牛女主播关于七牛云后台关闭主播房间的问题?
  • 2017-06-07 curl命令行是否可以json数据post请求和文件上传一次搞定?
  • 2017-06-07 saveas的传值能否用魔法变量?
  • 2017-06-07 mongoDB等非关系型数据库和mysql等关系型数据库的应用场景有何异同?
  • 2017-06-07 OpenCL执行效率问题
  • 2017-06-07 需要C#上传图片的demo
  • 2017-06-07 请问有没有一种类似ruby但容易开发桌面程序的编程语言?
  • 2017-06-07 一道阿里笔试题
  • 2017-06-07 python的redis库,连接池怎么用

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • python分包写入文件,写入固定字节文件,然后继续写入新文件
    • iOS的七牛SDK如何支持后台上传文件
    • (python)scrapy运行单个spider的时候,是不是只能利用单核资源?
    • (python)pandas读取中文的时候乱码要如何解决?
    • 七牛怎么取得返回值
    • JBOSS单独运行时正常,可是安装到myeclipse之后遇到了问题,求助
    • 七牛jssdk上传报错
    • 请问golang有成熟的分布式任务队列,类似python的celery
    • VBA防止SQL注入该如何实现
    • 怎样可以达到防止apk逆向工具运行?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有