棧:496.下一個更大元素 I

考點:單調棧

  • 有序棧
給定兩個沒有重復元素的數(shù)組 nums1 和 nums2 域帐,其中nums1 是 nums2 的子集。找到 nums1 中每個元素在 nums2 中的下一個比其大的值是整。

nums1 中數(shù)字 x 的下一個更大元素是指 x 在 nums2 中對應位置的右邊的第一個比 x 大的元素肖揣。如果不存在,對應位置輸出-1浮入。
示例 1:

輸入: nums1 = [4,1,2], nums2 = [1,3,4,2].
輸出: [-1,3,-1]
解釋:
    對于num1中的數(shù)字4龙优,你無法在第二個數(shù)組中找到下一個更大的數(shù)字,因此輸出 -1舵盈。
    對于num1中的數(shù)字1陋率,第二個數(shù)組中數(shù)字1右邊的下一個較大數(shù)字是 3。
    對于num1中的數(shù)字2秽晚,第二個數(shù)組中沒有下一個更大的數(shù)字瓦糟,因此輸出 -1。
示例 2:

輸入: nums1 = [2,4], nums2 = [1,2,3,4].
輸出: [3,-1]
解釋:
    對于num1中的數(shù)字2赴蝇,第二個數(shù)組中的下一個較大數(shù)字是3菩浙。
    對于num1中的數(shù)字4,第二個數(shù)組中沒有下一個更大的數(shù)字句伶,因此輸出 -1劲蜻。
注意:

nums1和nums2中所有元素是唯一的。

  • 將num2倒序入棧
  • 保持棧頂元素比新入棧元素大考余,否則出棧
  • 結果暫存map中以提高返回處理速度
package main

import (
    "container/list"
    "fmt"
    "strconv"
    "strings"
)

func nextGreaterElement(nums1 []int, nums2 []int) []int {
    var (
        numList list.List
        numMap  = make(map[int] int, 10)
        retList = nums1
    )

    for i := len(nums2) - 1; i >= 0; i -- {
        var result int
        if numList.Len() == 0 {
            result = -1
        }

        for true {
            if numList.Len() > 0 && numList.Back().Value.(int) <= nums2[i] {
                numList.Remove(numList.Back())
            } else {
                break
            }
        }

        if numList.Len() > 0 {
            result = numList.Back().Value.(int)
        } else {
            result = -1
        }

        numList.PushBack(nums2[i])
        numMap[nums2[i]] = result
    }

    for index, num := range nums1 {
        retList[index] = numMap[num]
    }

    return retList
}

func main() {
    var (
        sum_list string
        list_str []string

        num_list1 = []int{}
        num_list2 = []int{}
    )

    fmt.Println("輸入數(shù)組1:")
    fmt.Scan(&sum_list)

    list_str = strings.Split(sum_list, ",")
    for _, str := range list_str {
        tmp, _ := strconv.Atoi(str)
        num_list1 = append(num_list1, tmp)
    }

    fmt.Println("輸入數(shù)組2:")
    fmt.Scan(&sum_list)
    list_str = strings.Split(sum_list, ",")
    for _, str := range list_str {
        tmp, _ := strconv.Atoi(str)
        num_list2 = append(num_list2, tmp)
    }

    fmt.Println(nextGreaterElement(num_list1, num_list2))
}

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末先嬉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子楚堤,更是在濱河造成了極大的恐慌疫蔓,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件身冬,死亡現(xiàn)場離奇詭異衅胀,居然都是意外死亡,警方通過查閱死者的電腦和手機酥筝,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評論 2 384
  • 文/潘曉璐 我一進店門滚躯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人嘿歌,你說我怎么就攤上這事掸掏。” “怎么了搅幅?”我有些...
    開封第一講書人閱讀 156,623評論 0 345
  • 文/不壞的土叔 我叫張陵阅束,是天一觀的道長。 經(jīng)常有香客問我茄唐,道長息裸,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,324評論 1 282
  • 正文 為了忘掉前任沪编,我火速辦了婚禮呼盆,結果婚禮上,老公的妹妹穿的比我還像新娘蚁廓。我一直安慰自己访圃,他們只是感情好,可當我...
    茶點故事閱讀 65,390評論 5 384
  • 文/花漫 我一把揭開白布相嵌。 她就那樣靜靜地躺著腿时,像睡著了一般况脆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上批糟,一...
    開封第一講書人閱讀 49,741評論 1 289
  • 那天格了,我揣著相機與錄音,去河邊找鬼徽鼎。 笑死盛末,一個胖子當著我的面吹牛,可吹牛的內容都是我干的否淤。 我是一名探鬼主播悄但,決...
    沈念sama閱讀 38,892評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼石抡!你這毒婦竟也來了檐嚣?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,655評論 0 266
  • 序言:老撾萬榮一對情侶失蹤啰扛,失蹤者是張志新(化名)和其女友劉穎净嘀,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體侠讯,經(jīng)...
    沈念sama閱讀 44,104評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡挖藏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了厢漩。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片膜眠。...
    茶點故事閱讀 38,569評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖溜嗜,靈堂內的尸體忽然破棺而出宵膨,到底是詐尸還是另有隱情,我是刑警寧澤炸宵,帶...
    沈念sama閱讀 34,254評論 4 328
  • 正文 年R本政府宣布辟躏,位于F島的核電站,受9級特大地震影響土全,放射性物質發(fā)生泄漏捎琐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,834評論 3 312
  • 文/蒙蒙 一裹匙、第九天 我趴在偏房一處隱蔽的房頂上張望瑞凑。 院中可真熱鬧,春花似錦概页、人聲如沸籽御。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽技掏。三九已至铃将,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間哑梳,已是汗流浹背麸塞。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留涧衙,地道東北人。 一個月前我還...
    沈念sama閱讀 46,260評論 2 360
  • 正文 我出身青樓奥此,卻偏偏與公主長得像弧哎,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子稚虎,可洞房花燭夜當晚...
    茶點故事閱讀 43,446評論 2 348

推薦閱讀更多精彩內容

  • 【問題描述】給定兩個沒有重復元素的數(shù)組 nums1 和 nums2 撤嫩,其中nums1 是 nums2 的子集。找到...
    1江春水閱讀 386評論 0 2
  • 一些概念 數(shù)據(jù)結構就是研究數(shù)據(jù)的邏輯結構和物理結構以及它們之間相互關系蠢终,并對這種結構定義相應的運算序攘,而且確保經(jīng)過這...
    Winterfell_Z閱讀 5,690評論 0 13
  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴謹 對...
    cosWriter閱讀 11,090評論 1 32
  • Java集合類可用于存儲數(shù)量不等的對象,并可以實現(xiàn)常用的數(shù)據(jù)結構如棧,隊列等,Java集合還可以用于保存具有映射關...
    小徐andorid閱讀 1,922評論 0 13
  • 總結 想清楚再編碼 分析方法:舉例子、畫圖 第1節(jié):畫圖分析方法 對于二叉樹寻拂、二維數(shù)組程奠、鏈表等問題,都可以采用畫圖...
    M_巴拉巴拉閱讀 1,204評論 0 7