最大下标距离

43 篇文章 11 订阅
9 篇文章 0 订阅

题目 : 给定一个整型数组,找出最大的下标距离 ji ,当且仅当 A[i]<A[j] i<j

伪代码

int maxIndexDistance(int A[]){
  if (A==null || A.length<2) return 0;
  boolean inDescSeq[] = new boolean[A.length];
  int min = A[0],n=A.length;
  inDescSeq [0] = true;
  for(int i = 1;i <n;i++){
    if(A[i] < min){
      //做下降序列的标记
      inDescSeq[i] = true;
      min = A[i];
    }
  }
  int maxDist = 0,i=n-1,j=n-1;
  while(i>=0){
    if (inDescSeq[i] == false){
      i--; //倒序找出下一个降序列的元素
      continue;
    }
    while ((A[j] <= A[i]) && (j>i))
      j --; //从后往前移动直至找到符合的元素
    if((j-i) > maxDist){
      maxDist = j-i;
    }
    i--;
  }
  return (maxDist);
}

R语言

maxIndexDistance<-function(a)
{
  if (is.null(a) || length(a) < 2)
  {
    return (0)
  }
  inDescSeq = rep('FALSE',length(a))
  min = a[1];n=length(a)
  inDescSeq[1] = 'TRUE'
  for(i in 2:length(a))
  {
    if(a[i] < min)
    {
      inDescSeq[i] = 'TRUE'
      min = a[i]
    }
  }
  maxDist =0;i = n;j=n;
  while(i >= 1)
  {
    if(inDescSeq[i] == 'FALSE')
    {
      i = i -1;
    }
    while ((a[j] <= a[i]) && (j > i))
    {
      j = j-1
    }
    if ((j-i) > maxDist)
    {
      maxDist = j-i
    }
    i = i -1
  }
  return(maxDist)
}


#1
> a<-c(1:20,30:14,2:23,54:33)
> maxIndexDistance(a)
[1] 59

#2
> a<-c(5,3,4,0,1,4,1)
> maxIndexDistance(a)
[1] 4

python

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值