數(shù)據(jù)結(jié)構(gòu):最大下標(biāo)距離

本文首發(fā)為CSDN博客捧颅,地址為:http://blog.csdn.net/xxzhangx/article/details/53505867

歡迎關(guān)注景图,謝謝!引用轉(zhuǎn)載請注明作者和地址碉哑!

題目 : 給定一個整型數(shù)組挚币,找出最大的下標(biāo)距離j-i扣典,當(dāng)且僅當(dāng)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){
      //做下降序列的標(biāo)記
      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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末笛粘,一起剝皮案震驚了整個濱河市湿硝,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌关斜,老刑警劉巖示括,帶你破解...
    沈念sama閱讀 218,204評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件垛膝,死亡現(xiàn)場離奇詭異,居然都是意外死亡繁涂,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,091評論 3 395
  • 文/潘曉璐 我一進(jìn)店門扔罪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人桶雀,你說我怎么就攤上這事唬复∪梗” “怎么了敞咧?”我有些...
    開封第一講書人閱讀 164,548評論 0 354
  • 文/不壞的土叔 我叫張陵休建,是天一觀的道長。 經(jīng)常有香客問我测砂,道長,這世上最難降的妖魔是什么砌些? 我笑而不...
    開封第一講書人閱讀 58,657評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮加匈,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘雕拼。我一直安慰自己,他們只是感情好啥寇,可當(dāng)我...
    茶點故事閱讀 67,689評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著甜橱,像睡著了一般逊笆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上难裆,一...
    開封第一講書人閱讀 51,554評論 1 305
  • 那天乃戈,我揣著相機(jī)與錄音褂痰,去河邊找鬼症虑。 笑死,一個胖子當(dāng)著我的面吹牛谍憔,可吹牛的內(nèi)容都是我干的主籍。 我是一名探鬼主播,決...
    沈念sama閱讀 40,302評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼千元,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了幸海?” 一聲冷哼從身側(cè)響起奥务,我...
    開封第一講書人閱讀 39,216評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎汗洒,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體溢谤,經(jīng)...
    沈念sama閱讀 45,661評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,851評論 3 336
  • 正文 我和宋清朗相戀三年阀参,在試婚紗的時候發(fā)現(xiàn)自己被綠了瞻坝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛛壳。...
    茶點故事閱讀 39,977評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡衙荐,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出忧吟,到底是詐尸還是另有隱情,我是刑警寧澤溜族,帶...
    沈念sama閱讀 35,697評論 5 347
  • 正文 年R本政府宣布垦沉,位于F島的核電站煌抒,受9級特大地震影響厕倍,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,306評論 3 330
  • 文/蒙蒙 一屋群、第九天 我趴在偏房一處隱蔽的房頂上張望坏挠。 院中可真熱鬧芍躏,春花似錦降狠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,898評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蛋褥。三九已至,卻和暖如春烙心,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背淫茵。 一陣腳步聲響...
    開封第一講書人閱讀 33,019評論 1 270
  • 我被黑心中介騙來泰國打工匙瘪, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留铆铆,地道東北人丹喻。 一個月前我還...
    沈念sama閱讀 48,138評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像碍论,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子骑冗,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,927評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,133評論 25 707
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗贼涩。 張土汪:刷leetcod...
    土汪閱讀 12,745評論 0 33
  • 算法、數(shù)據(jù)結(jié)構(gòu) 1.數(shù)組和鏈表什么區(qū)別? ?數(shù)組是將元素在內(nèi)存中連續(xù)存放袒哥,由于每個元素占用內(nèi)存相同,可以通過下標(biāo)迅...
    丶逐漸閱讀 544評論 0 1
  • 女主角是我初中就認(rèn)識的閨蜜桐臊。可能算不算閨蜜吧晓殊,因為在我們認(rèn)識的10年里可能有約莫5、6年的時間是在冷戰(zhàn)的巫俺,那時候我...
    韓夢櫻閱讀 347評論 0 1
  • 1、周姜華——別讓孩子輸在起跑線上却嗡,這句話我們到底在討論什么? 標(biāo)題:別讓孩子輸在起跑線上稽穆,這句話我們到底在討論什...
    卡拉手記閱讀 852評論 0 0