訪問所有節(jié)點的最短路徑

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/shortest-path-visiting-all-nodes

題目描述:

存在一個由 n 個節(jié)點組成的無向連通圖答倡,圖中的節(jié)點按從 0 到 n - 1 編號使鹅。
給你一個數(shù)組 graph 表示這個圖。其中,graph[i] 是一個列表含思,由所有與節(jié)點 i 直接相連的節(jié)點組成。
返回能夠訪問所有節(jié)點的最短路徑的長度纱意。你可以在任一節(jié)點開始和停止俐东,也可以多次重訪節(jié)點,并且可以重用邊痘系。

示例 1:

輸入:graph = [[1,2,3],[0],[0],[0]]
輸出:4
解釋:一種可能的路徑為 [1,0,2,0,3]

示例 2:

輸入:graph = [[1],[0,2,4],[1,3,4],[2],[1,2]]
輸出:4
解釋:一種可能的路徑為 [0,1,4,2,3]

題目分析:
  • 等權(quán)(權(quán)可以看作1)無向圖求最短路徑問題
  • 可以從任意節(jié)點開始
  • 節(jié)點可以重復(fù)訪問
  • 最多12個節(jié)點,1 <= n <= 12
思路分析:

因為n最大只有12菲嘴,且是等權(quán)圖求最短路徑,很容易想到bfs+狀態(tài)壓縮點方法.

  • 訪問第 i 個點的狀態(tài)(1表示已經(jīng)訪問過) : state = 1 & (i >>1)
  • 更改第 i 個點狀態(tài)為1 : mark = mark | (1 << i)
  • 判斷row個節(jié)點是否已經(jīng)全部遍歷:mark = 2^n - 1;
代碼實現(xiàn):
class Solution {
    public int shortestPathLength(int[][] graph) {
        int row = graph.length;
        boolean[][] flag = new boolean[row][1 << row];
        Queue<int[]> queue = new LinkedList();
        for (int i = 0; i < row; i++) {
            queue.offer(new int[]{i, 1 << i, 0}); // 可以任意起點,將所有節(jié)點初始化到queue.
            flag[i][1 << i] = true;
        }
        while (!queue.isEmpty()) {
            int[] temp = queue.poll();
            int node = temp[0]; // 當(dāng)前節(jié)點
            int mark = temp[1]; // 當(dāng)前節(jié)點狀態(tài)
            int result = temp[2]; // 當(dāng)前走過的路徑(權(quán)值和)
            if (mark == (1 << row) - 1) return result; // 節(jié)點已經(jīng)全部遍歷.
            for (int num : graph[node]) {
                int nextMark = mark | (1 << num); // 修改num節(jié)點點狀態(tài)
                if (!flag[num][nextMark]) {
                    queue.offer(new int[]{num, nextMark, result + 1}); // 擴展下一輪節(jié)點.
                    flag[num][nextMark] = true; // 標(biāo)記已經(jīng)訪問的節(jié)點.
                }
            }
        }
        return 0;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末汰翠,一起剝皮案震驚了整個濱河市龄坪,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌复唤,老刑警劉巖健田,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異佛纫,居然都是意外死亡妓局,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門呈宇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來跟磨,“玉大人,你說我怎么就攤上這事攒盈〉志校” “怎么了?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵型豁,是天一觀的道長僵蛛。 經(jīng)常有香客問我,道長迎变,這世上最難降的妖魔是什么充尉? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮衣形,結(jié)果婚禮上驼侠,老公的妹妹穿的比我還像新娘姿鸿。我一直安慰自己,他們只是感情好倒源,可當(dāng)我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布苛预。 她就那樣靜靜地躺著,像睡著了一般笋熬。 火紅的嫁衣襯著肌膚如雪热某。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天胳螟,我揣著相機與錄音昔馋,去河邊找鬼。 笑死糖耸,一個胖子當(dāng)著我的面吹牛秘遏,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播嘉竟,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼垄提,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了周拐?” 一聲冷哼從身側(cè)響起铡俐,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎妥粟,沒想到半個月后审丘,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡勾给,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年滩报,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片播急。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡脓钾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出桩警,到底是詐尸還是另有隱情可训,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布捶枢,位于F島的核電站握截,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏烂叔。R本人自食惡果不足惜谨胞,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蒜鸡。 院中可真熱鬧胯努,春花似錦牢裳、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至恬汁,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間辜伟,已是汗流浹背氓侧。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留导狡,地道東北人约巷。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像旱捧,于是被迫代替她去往敵國和親独郎。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,802評論 2 345

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