【LeetCode】1266. Minimum Time Visiting All Points

題意

在2D平面上給出n個(gè)整數(shù)點(diǎn)pointspoints[i] = [xi, yi]饱狂, xiyi都是整數(shù)宪彩,訪問(wèn)所有points需要多少秒休讳?
其中:

  • 水平移動(dòng)一個(gè)單元、垂直移動(dòng)一個(gè)單元尿孔、對(duì)角移動(dòng)一個(gè)單元(水平移動(dòng)一次衍腥、垂直移動(dòng)一次)都認(rèn)為只耗時(shí)1秒磺樱;
  • 只能順序訪問(wèn)points;

解法

拿到題目后核心需要解決從A點(diǎn)到B點(diǎn)需要多少秒,知道AB兩點(diǎn)需要多少秒后婆咸,后面只需要遍歷points重復(fù)計(jì)算即可。
A芜辕、B點(diǎn)可以形成兩種類(lèi)型的矩形尚骄,瘦矩形和胖矩形,由于對(duì)角移動(dòng)只耗時(shí)1秒(相當(dāng)于移動(dòng)了兩次一次水平一次垂直侵续,優(yōu)于直接進(jìn)行水平移動(dòng)和垂直移動(dòng))倔丈,所以A到B點(diǎn)優(yōu)先對(duì)角移動(dòng),使對(duì)角移動(dòng)最大化状蜗,然后再水平或者垂直移動(dòng)需五。

  • 針對(duì)瘦矩形 (|x2-x1| < |y2-y1|)

從A點(diǎn)(1,1)到B點(diǎn)(3,6)最優(yōu)耗時(shí)計(jì)算:先對(duì)角移動(dòng)在垂直移動(dòng)(1,1)->(3,3)->(3,6)
瘦矩陣移動(dòng)耗時(shí)移動(dòng)路徑(x1,y1)->(x2,x2)->(x2,y2)
通用計(jì)算:|x2-x1|+(|y2-y1|-|x2-x1|)

  • 針對(duì)胖矩形 (|x2-x1|>|y2-y1|)

從A點(diǎn)(1,1)到B點(diǎn)(6,3)最優(yōu)耗時(shí)計(jì)算:先對(duì)角移動(dòng)在垂直移動(dòng)(1,1)->(3,3)->(6,3)
瘦矩陣移動(dòng)耗時(shí)移動(dòng)路徑(x1,y1)->(y2,y2)->(x2,y2)
通用計(jì)算:|y2-y1|+(|x2-x1|-|y2-y1|)

結(jié)合胖矩陣和瘦矩陣,最后A(x1, y1)點(diǎn)到B(x2, y2)點(diǎn)的耗時(shí)為:
\begin{equation} sum = \left\{ \begin{array}{cc} |x2-x1| + (|y2-y1|-|x2-x1|) & 當(dāng)|x2-x1| < |y2-y1|時(shí) \\ |y2-y1| + (|x2-x1|-|y2-y1|) & 當(dāng)|x2-x1| >= |y2-y1|時(shí) \end{array} \right. \end{equation}

綜合得sum=min(|x2-x1|, |y2-y1|)+abs(|y2-y1|-|x2-x1|)

代碼

class Solution {
public:
    int minTimeToVisitAllPoints(vector<vector<int>>& points) {
        int sum = 0;
        for (size_t i = 1; i < points.size(); ++ i) {
            int xt = abs(points[i][0]-points[i-1][0]);
            int yt = abs(points[i][1]-points[i-1][1]);
            sum += min(xt, yt) + abs(yt-xt);
        }
        return sum;
    }
};
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末轧坎,一起剝皮案震驚了整個(gè)濱河市宏邮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌缸血,老刑警劉巖蜜氨,帶你破解...
    沈念sama閱讀 218,451評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異捎泻,居然都是意外死亡飒炎,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)笆豁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)郎汪,“玉大人,你說(shuō)我怎么就攤上這事闯狱∩酚” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,782評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵扩氢,是天一觀的道長(zhǎng)耕驰。 經(jīng)常有香客問(wèn)我,道長(zhǎng)录豺,這世上最難降的妖魔是什么朦肘? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,709評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮双饥,結(jié)果婚禮上媒抠,老公的妹妹穿的比我還像新娘。我一直安慰自己咏花,他們只是感情好趴生,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布阀趴。 她就那樣靜靜地躺著,像睡著了一般苍匆。 火紅的嫁衣襯著肌膚如雪刘急。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,578評(píng)論 1 305
  • 那天浸踩,我揣著相機(jī)與錄音叔汁,去河邊找鬼。 笑死检碗,一個(gè)胖子當(dāng)著我的面吹牛据块,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播折剃,決...
    沈念sama閱讀 40,320評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼另假,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了怕犁?” 一聲冷哼從身側(cè)響起边篮,我...
    開(kāi)封第一講書(shū)人閱讀 39,241評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎因苹,沒(méi)想到半個(gè)月后苟耻,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,686評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡扶檐,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評(píng)論 3 336
  • 正文 我和宋清朗相戀三年凶杖,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片款筑。...
    茶點(diǎn)故事閱讀 39,992評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡智蝠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出奈梳,到底是詐尸還是另有隱情杈湾,我是刑警寧澤,帶...
    沈念sama閱讀 35,715評(píng)論 5 346
  • 正文 年R本政府宣布攘须,位于F島的核電站漆撞,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏于宙。R本人自食惡果不足惜浮驳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望捞魁。 院中可真熱鬧至会,春花似錦、人聲如沸谱俭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,912評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至县貌,卻和暖如春术陶,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背煤痕。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,040評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工瞳别, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人杭攻。 一個(gè)月前我還...
    沈念sama閱讀 48,173評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像疤坝,于是被迫代替她去往敵國(guó)和親兆解。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評(píng)論 2 355

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

  • 來(lái)源: http://www.douban.com/group/topic/14820131/ 調(diào)整變量格式: f...
    MC1229閱讀 6,919評(píng)論 0 5
  • 一跑揉、添加一個(gè) Canvas 1.布置畫(huà)布:通過(guò)添加<canvas>標(biāo)簽锅睛,添加canvas元素 Canvas在HTM...
    Lia代碼豬崽閱讀 2,221評(píng)論 0 3
  • 什么是SVG? SVG 指可伸縮矢量圖形 (Scalable Vector Graphics) SVG 用來(lái)定義用...
    hojun閱讀 877評(píng)論 0 5
  • 卻原來(lái)历谍,有很多人可以忘記现拒,有很多人可刪,很多事可以忘記望侈,回憶也能忘記印蔬,啥也沒(méi)了。真好脱衙,干凈了侥猬。 這么多以前不舍得刪...
    am薄荷糖閱讀 61評(píng)論 0 1
  • 今天讀知識(shí)就是力量,看到羅胖講他每天60秒的語(yǔ)音一秒不多一秒不少地搞了5年捐韩,我突發(fā)奇想在群里鼓動(dòng)朋友每人每周發(fā)一條...
    第二夢(mèng)想閱讀 172評(píng)論 0 0