605.序列重構(gòu)

描述

判斷是否序列 org 能唯一地由 seqs 重構(gòu)得出. org 是一個(gè)由從1 到 n 的正整數(shù)排列而成的序列进鸠,1 ≤ n ≤ 10^4揪垄。 重構(gòu)表示組合成 seqs 的一個(gè)最短的父序列 (意思是幽崩,一個(gè)最短的序列使得所有 seqs 里的序列都是它的子序列).
判斷是否有且僅有一個(gè)能從 seqs 重構(gòu)出來的序列逊谋,并且這個(gè)序列是org取刃。

樣例

給定 org = [1,2,3], seqs = [[1,2],[1,3]]
返回 false
解釋:
[1,2,3] 并不是唯一可以被重構(gòu)出的序列吧彪,還可以重構(gòu)出 [1,3,2]
給出 org = [1,2,3], seqs = [[1,2]]
返回 false
解釋:
能重構(gòu)出的序列只有 [1,2].
給定 org = [1,2,3], seqs = [[1,2],[1,3],[2,3]]
返回 true
解釋:
序列 [1,2], [1,3], 和 [2,3] 可以唯一重構(gòu)出 [1,2,3].
給定org = [4,1,5,2,6,3], seqs = [[5,2,6,3],[4,1,5,2]]
返回 true

思路

用 seqs 進(jìn)行拓?fù)渑判虻玫綌?shù)組待侵,判斷 org 是否是唯一解

代碼

public class Solution {
    /**
     * @param org a permutation of the integers from 1 to n
     * @param seqs a list of sequences
     * @return true if it can be reconstructed only one or false
     */
    public boolean sequenceReconstruction(int[] org, int[][] seqs) {
        Map<Integer, Set<Integer>> map = new HashMap<Integer, Set<Integer>>();
        Map<Integer, Integer> indegree = new HashMap<Integer, Integer>();
        
        // 給 org 中每個(gè)元素進(jìn)行 map 和度的初始化
        for (int num : org) {
            map.put(num, new HashSet<Integer>());
            indegree.put(num, 0);
        }

        int n = org.length;
        int count = 0;
        // seq 是 seqs 的一維數(shù)組
        for (int[] seq : seqs) {
            count += seq.length;
            // seq[0] 和 seq[1] ... seq[n] 要分開寫,因?yàn)?i - 1 在 i = 0 時(shí)會(huì)越界
            if (seq.length >= 1 && (seq[0] <= 0 || seq[0] > n)) {
                return false;
            }

            // seq 有兩個(gè)以上元素時(shí)
            for (int i = 1; i < seq.length; i++) {
                // seq 中元素不符合 org 中要求
                if (seq[i] <= 0 || seq[i] > n) {
                    return false;
                }
                // 檢查 seq[i] 和 seq[i - 1] 間有沒有映射姨裸,沒有建立個(gè)映射
                // 實(shí)際上就是去重復(fù)秧倾,然后添加 hash 并且統(tǒng)計(jì)度
                if (map.get(seq[i - 1]).add(seq[i])) {
                    indegree.put(seq[i], indegree.get(seq[i]) + 1);
                }
            }
        }

        // 所有 seq 的長度加一起應(yīng)該大于等于 n,seq 中可能存在重復(fù)元素
        if (count < n) {
            return false;
        }
        
        // bfs  
        // 度為 0 的加入隊(duì)列
        Queue<Integer> q = new ArrayDeque<Integer>();
        for (int key : indegree.keySet()) {
            if (indegree.get(key) == 0) {
                q.add(key);
            }
        }
        
    // 用 seqs 進(jìn)行拓?fù)渑判虻玫叫碌慕M合序列啦扬,和org每個(gè)位置一一對(duì)比
        int cnt = 0;
        
        
        // 因?yàn)槭俏ㄒ粯?gòu)成中狂,所以每個(gè)元素的先序應(yīng)該只有一個(gè),即度為1
        // 只有每次queue中只有一個(gè)元素的時(shí)候扑毡,產(chǎn)生的序列才是唯一的
        while (q.size() == 1) {
            int ele = q.poll();
            for (int next : map.get(ele)) {
                indegree.put(next, indegree.get(next) - 1);
                if (indegree.get(next) == 0) {
                    q.add(next);
                }
            }
            // 判斷新的序列每個(gè)位置和 org 相不相等
            if (ele != org[cnt]) {
                return false;
            }
            cnt++;
        }
        
    // 判斷新構(gòu)造的數(shù)組元素總數(shù)和 org 相不相等
        // 可能會(huì)出現(xiàn)新構(gòu)造的數(shù)組是 org 的子集或者 org 是新構(gòu)造的數(shù)組的子集
        return cnt == org.length;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末胃榕,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子瞄摊,更是在濱河造成了極大的恐慌勋又,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件换帜,死亡現(xiàn)場(chǎng)離奇詭異楔壤,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)惯驼,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門蹲嚣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人祟牲,你說我怎么就攤上這事隙畜。” “怎么了说贝?”我有些...
    開封第一講書人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵议惰,是天一觀的道長。 經(jīng)常有香客問我乡恕,道長言询,這世上最難降的妖魔是什么俯萎? 我笑而不...
    開封第一講書人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮运杭,結(jié)果婚禮上夫啊,老公的妹妹穿的比我還像新娘。我一直安慰自己辆憔,他們只是感情好涮母,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著躁愿,像睡著了一般。 火紅的嫁衣襯著肌膚如雪沪蓬。 梳的紋絲不亂的頭發(fā)上彤钟,一...
    開封第一講書人閱讀 49,079評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音跷叉,去河邊找鬼逸雹。 笑死,一個(gè)胖子當(dāng)著我的面吹牛云挟,可吹牛的內(nèi)容都是我干的梆砸。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼园欣,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼帖世!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起沸枯,我...
    開封第一講書人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤日矫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后绑榴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體哪轿,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年翔怎,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了窃诉。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赤套,死狀恐怖飘痛,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情于毙,我是刑警寧澤敦冬,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布,位于F島的核電站唯沮,受9級(jí)特大地震影響脖旱,放射性物質(zhì)發(fā)生泄漏堪遂。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一萌庆、第九天 我趴在偏房一處隱蔽的房頂上張望溶褪。 院中可真熱鬧,春花似錦践险、人聲如沸猿妈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽彭则。三九已至,卻和暖如春占遥,著一層夾襖步出監(jiān)牢的瞬間俯抖,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來泰國打工瓦胎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留时肿,地道東北人姑裂。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓捻悯,卻偏偏與公主長得像蘸拔,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子负芋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

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