python最大数的下标_算法--最大下标差

题目:

Given an array arr[], find the maximum j – i such that arr[j] > arr[i]

一个数组,找出最大下标差j-i,且a[i]

分析:

i必定在以第一个元素开始的降序列中(可以采用反正发证明:假设存在最大下标距离的两个下标i和j,i

python 代码:

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

from random import randint

#generate a unsorted list

origin = []

def randomList():

for i in xrange(0,10,1):

origin.append(randint(-10,10))

print origin

return origin

def maxSpan(data):

lmin = []

rmax = []

temp = data[0]

lmin.append(0)

for i in xrange(1,len(data)):

if data[i] < temp:

lmin.append(i)

temp = data[i]

else:

pass

length = len(data)

temp = data[length-1]

rmax.append(length-1)

for i in xrange(length-2,-1,-1):

if data[i] > temp:

rmax.insert(0,i)

temp = data[i]

else:

pass

i,j = 0,0

result = 0

while i < len(lmin) and j < len(rmax):

if data[lmin[i]] < data[rmax[j]]:

# print data[lmin[i]],data[rmax[j]],lmin[i],rmax[j]

result = result if result > (rmax[j]-lmin[i]) else (rmax[j]-lmin[i])

j += 1

else:

i += 1

print result

if __name__ == "__main__":

maxSpan(randomList())

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值