220. Contains Duplicate III 存在重復(fù)元素 |||

題目鏈接
tag:

  • Medium贬媒;

question:
??Given an array of integers, find out whether there are two distinct indices i and j in the array such that the absolute difference between nums[i] and nums[j] is at most t and the absolute difference between i and j is at most k.

Example 1:

Input: nums = [1,2,3,1], k = 3, t = 0
Output: true

Example 2:

Input: nums = [1,0,1,1], k = 1, t = 2
Output: true

Example 3:

Input: nums = [1,5,9,1,5,9], k = 2, t = 3
Output: false

思路:
??這道題跟之前兩道Contains Duplicate 存在重復(fù)值Contains Duplicate II 存在重復(fù)值 ||的關(guān)聯(lián)并不大,前兩道起碼跟重復(fù)值有關(guān)委煤,這道題的焦點(diǎn)不是在重復(fù)值上面绷蹲,反而是關(guān)注與不同的值之間的關(guān)系棒卷,這里有兩個(gè)限制條件,兩個(gè)數(shù)字的坐標(biāo)差不能大于k瘸右,值差不能大于t娇跟。
??這道題如果用brute force會(huì)超時(shí),所以我們只能另辟蹊徑太颤。這里我們使用map數(shù)據(jù)結(jié)構(gòu)來(lái)解苞俘,用來(lái)記錄數(shù)字和其下標(biāo)之間的映射。 這里需要兩個(gè)指針i和j龄章,剛開始i和j都指向0吃谣,然后i開始向右走遍歷數(shù)組,如果i和j之差大于k做裙,且m中有nums[j]岗憋,則刪除并j加一。這樣保證了m中所有的數(shù)的下標(biāo)之差都不大于k锚贱,然后我們用map數(shù)據(jù)結(jié)構(gòu)的lower_bound()函數(shù)來(lái)找一個(gè)特定范圍仔戈,就是大于或等于nums[i] - t的地方,所有小于這個(gè)閾值的數(shù)和nums[i]的差的絕對(duì)值會(huì)大于t。然后檢測(cè)后面的所有的數(shù)字监徘,如果數(shù)的差的絕對(duì)值小于等于t晋修,則返回true。最后遍歷完整個(gè)數(shù)組返回false凰盔。代碼如下:

class Solution {
public:
    bool containsNearbyAlmostDuplicate(vector<int>& nums, int k, int t) {
        map<long long, int> m;
        int j = 0;
        for (int i=0; i<nums.size(); ++i) {
            if (i - j > k) 
                m.erase(nums[j++]);
            auto a = m.lower_bound((long long)nums[i] - t);
            if (a != m.end() && abs(a->first - nums[i]) <= t) 
                return true;
            m[nums[i]] = i;
        }
        return false;
    }
}; 
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末墓卦,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子户敬,更是在濱河造成了極大的恐慌落剪,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件尿庐,死亡現(xiàn)場(chǎng)離奇詭異忠怖,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)屁倔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門脑又,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人锐借,你說(shuō)我怎么就攤上這事问麸。” “怎么了钞翔?”我有些...
    開封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵严卖,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我布轿,道長(zhǎng)哮笆,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任汰扭,我火速辦了婚禮稠肘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘萝毛。我一直安慰自己项阴,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開白布笆包。 她就那樣靜靜地躺著环揽,像睡著了一般。 火紅的嫁衣襯著肌膚如雪庵佣。 梳的紋絲不亂的頭發(fā)上歉胶,一...
    開封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音巴粪,去河邊找鬼通今。 笑死粥谬,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的衡创。 我是一名探鬼主播帝嗡,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼璃氢!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起狮辽,我...
    開封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤一也,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后喉脖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體椰苟,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年树叽,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了舆蝴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡题诵,死狀恐怖洁仗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情性锭,我是刑警寧澤赠潦,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站草冈,受9級(jí)特大地震影響她奥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜怎棱,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一哩俭、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧拳恋,春花似錦凡资、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至吩谦,卻和暖如春鸳谜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背式廷。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工咐扭, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓蝗肪,卻偏偏與公主長(zhǎng)得像袜爪,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子薛闪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

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