剑指offer 面试51题
2024-08-27 22:41:25
面试51题:
题目:数组中的逆序对
题目描述
在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数P。并将P对1000000007取模的结果输出。 即输出P%1000000007
输入描述:
题目保证输入的数组中没有的相同的数字
数据范围:
对于%50的数据,size<=10^4
对于%75的数据,size<=10^5
对于%100的数据,size<=2*10^5
解题代码:
# -*- coding:utf-8 -*-
class Solution:
#方法一:巧妙的方法,来源牛客网
def InversePairs(self, data):
if len(data) <= 0:
return 0
count = 0
copy = []
for i in range(len(data)):
copy.append(data[i])
copy.sort()
i = 0
while len(copy) > i:
count += data.index(copy[i])
data.remove(copy[i])
i += 1
return count%1000000007 #暴力法
def InversePairs2(self, data):
if len(data)<=1:
return 0
count=0
length=len(data)
for i in range(length-1):
for j in range(i+1,length):
if data[i]>data[j]:
count+=1
return count % 1000000007 #归并排序法
def InversePairs3(self, data):
if len(data)<=0:
return 0
length=len(data)
copy=[0]*length
for i in range(length):
copy[i]=data[i]
#copy数组为原数组data的复制,在后面充当辅助数组
count=self.Core(data,copy,0,length-1)
return count % 1000000007 def Core(self,data,copy,start,end):
if start==end:
copy[start]=data[start]
return 0 length=(end-start)//2 #length为划分后子数组的长度 left=self.Core(copy,data,start,start+length)
right=self.Core(copy,data,start+length+1,end) #初始化i为前半段最后一个数字的下标
i=start+length
#初始化j为后半段最后一个数字的下标
j=end #indexCopy为辅助数组的指针,初始化其指向最后一位
indexCopy=end
#准备开始计数
count=0
#对两个数组进行对比取值的操作:
while i>=start and j>=start+length+1:
if data[i]>data[j]:
copy[indexCopy]=data[i]
indexCopy-=1
i-=1
count += j-start-length
else:
copy[indexCopy]=data[j]
indexCopy-=1
j-=1 #剩下一个数组未取完的操作:
while i>=start:
copy[indexCopy]=data[i]
indexCopy-=1
i-=1
while j>=start+length+1:
copy[indexCopy]=data[j]
indexCopy-=1
j-=1 return count+left+right
最新文章
- A Complete List of .NET Open Source Developer Projects
- 原创最简单的ORM例子
- php之aop实践
- 【EF学习笔记07】----------加载关联表的数据 贪婪加载
- sql注入实例分析
- 烟大 Contest1024 - 《挑战编程》第一章:入门 Problem D: LC-Display(模拟计算器显示数字)
- Hibernate三种状态的转换
- shell 从文件按行读
- Myeclipse下不用dom4j等解析xml文档
- VC++ 坐标问题总结,控件大小随窗口变化
- zoj3204 Connect them 最小生成树
- javaIO流实现文件拷贝
- LuoguP4234_最小差值生成树_LCT
- iOS开发GCD(3)-数据安全
- python中的多进程与多线程(一)
- 全局eslint不生效的处理
- BZOJ3252 攻略 [树链剖分]
- 托管C++调用C#
- php 使用html5 XHR2 上传文件 进度显示
- Failed to load JavaHL Library. SVN
热门文章
- testng入门_单元测试
- java - day11 - OverRideTest
- linux fedora 14(内核2.6.35.6) PF_RING+libpcap 极速捕获千兆网数据包,不丢包
- Consul实现原理系列文章3: Consul的整体架构
- CMake 简介与使用
- Java进阶02 异常处理(转载)
- Bootstrap -- 标签属性
- -webkit-transition: all .2s ease-in-out;
- Laravel5.1 模型--ModelFactory
- ubuntu 16.04 系统语言汉化