摘要:拓?fù)渑判驈?fù)雜度時間空間思路本題和的解法一樣,不會拓?fù)渑判虻目梢詤⒖寄瞧恼?。區(qū)別在于我們拓?fù)渑判蚝蟮脑L問順序,本來我們是用一個來進行,這里為了讓依賴少的先安裝,我們將換成,并以依賴數(shù)排序。
Install Dependencies
拓?fù)渑判?/b> 復(fù)雜度給定軟件之間安裝的依賴關(guān)系,用一個二維數(shù)組表示,第一維表示依賴的序號,第二維表示依賴關(guān)系,比如要先裝deps[0][0],才能裝deps[0][1]。安裝時,要盡可能先安裝依賴個數(shù)少的軟件。求安裝順序。
時間 O(1) 空間 O(1)
思路本題和Course Schedule的解法一樣,不會拓?fù)渑判虻目梢詤⒖寄瞧恼?。區(qū)別在于我們拓?fù)渑判蚝蟮脑L問順序,本來我們是用一個Queue來進行BFS,這里為了讓依賴少的先安裝,我們將Queue換成PriorityQueue,并以依賴數(shù)排序。用優(yōu)先隊列遍歷圖,很像是Cost based search 或者greedy,a star這種算法。注意,由于可能出現(xiàn)兩個軟件有同樣依賴數(shù)的情況,比如兩個軟件剩余依賴都是0的時候,應(yīng)該先裝哪個呢?這個就要和面試官討論了,可以在軟件的數(shù)據(jù)結(jié)構(gòu)中加入timestamp或者總依賴數(shù)等變量,供我們在ProrityQueue中作為第二個、第三個條件來比較。
代碼public class InstallDependencies { public static void main(String[] args){ String[][] deps = {{"gcc", "gdb"},{"gcc", "visualstudio"},{"windows", "gcc"} , {"windows", "sublime"}, {"libc", "gcc"}, {"libc2", "gcc"}, {"unix", "cat"} , {"windows", "libc"}, {"windows", "libc2"}, {"linux", "cat"}, {"windows", "cat"} , {"solaris", "cat"}, {"macos","cat"}}; InstallDependencies id = new InstallDependencies(); id.install(deps, 7); } public void install(String[][] deps, int n){ HashMapmap = new HashMap (); // 根據(jù)依賴關(guān)系建圖 for(String[] dep : deps){ Software src = map.get(dep[0]); Software dst = map.get(dep[1]); if(src == null){ src = new Software(dep[0]); } if(dst == null){ dst = new Software(dep[1]); } src.targets.add(dst); dst.deps = dst.deps + 1; map.put(dep[0], src); map.put(dep[1], dst); } // 用一個優(yōu)先隊列來遍歷我們的圖 PriorityQueue pq = new PriorityQueue (11 ,new Comparator (){ public int compare(Software s1, Software s2){ return s1.deps - s2.deps; } }); for(String name : map.keySet()){ if(map.get(name).deps == 0){ pq.offer(map.get(name)); } } while(!pq.isEmpty()){ Software curr = pq.poll(); System.out.println(curr.name); for(Software dst : curr.targets){ dst.deps = dst.deps - 1; if(dst.deps == 0){ pq.offer(dst); } } } } } class Software{ String name; int deps; ArrayList targets; public Software(String name){ this.deps = 0; this.name = name; this.targets = new ArrayList (); } }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66172.html
摘要:你很明白嗎依賴開發(fā)依賴當(dāng)我們敲的時候會安裝哪些依賴,和都會安裝嗎還是只安裝項目依賴包是放在和簡單問兩個問題,勾起大家對,,的回憶。和還是有明顯區(qū)別的。結(jié)論當(dāng)你在開發(fā)一個包的時候,還是要好好管理你的依賴和依賴。 npm install 你很明白嗎dependencies 依賴devDependencies 開發(fā)依賴 【當(dāng)我們敲 npm install 的時候會安裝哪些依賴,depende...
摘要:如果版本尚未發(fā)布到注冊表,則會失敗。參數(shù)將阻止安裝可選的依賴項。參數(shù),它將忽略可用的包鎖或文件,而是使用。參數(shù)可用于禁止將審計報告發(fā)送到已配置的注冊表。 我覺得所有程序員都在努力的學(xué)習(xí)閱讀英語吧,畢竟英語閱讀沒問題,我們才能更好的閱讀文檔,為了給大家更快的學(xué)習(xí)效率,所以翻譯了這一篇中英文對照的文章。如果你每次安裝package包時候會想,what?各種命令--save -D 之類的究...
摘要:本文是系列的第一篇,知識很基礎(chǔ),作為一個熱身文章,如果各位已經(jīng)是開發(fā)熟練工了,完全可以跳過這篇。系列匯總什么是系列一簡介什么是系列二的十八般武藝本文同步發(fā)表博客什么是系列一簡介 showImg(https://segmentfault.com/img/bVbwqLS?w=1400&h=545); npm是Node.js的包管理工具,它的誕生也極大的促進了前端的發(fā)展,在現(xiàn)代前端開發(fā)中都離...
摘要:會將模塊依賴寫入節(jié)點。運行初始化項目時,會將模塊下載到項目目錄下。運行或者注明變量值為時,不會自動下載模塊到目錄中開發(fā)環(huán)境。這些模塊在我們的項目部署后是不需要的,所以我們可以使用的形式安裝。 npm install packageName //本地安裝,安裝到項目目錄下,不在package.json中寫入依賴npm install packageName -g //全局安...
摘要:但往往中指定的是一個版本范圍,例如以上這個指定的范圍是版本號大于等于且大版本號為。之后的機制滿足了要求鎖版本的開發(fā)者們的需要,我們只需要拿到一份就可以知道要安裝的依賴的具體版本號。 npm是什么 npm是一個包管理工具,開源作者可以把開源包發(fā)布在平臺上供其他人下載使用。前端的同學(xué)基本都使用過npm,這里就不做過多介紹。日常工作中npm的主要用途就是根據(jù)項目的package.json使用...
閱讀 3250·2021-11-15 11:37
閱讀 2464·2021-09-29 09:48
閱讀 3828·2021-09-22 15:55
閱讀 3025·2021-09-22 10:02
閱讀 2649·2021-08-25 09:40
閱讀 3240·2021-08-03 14:03
閱讀 1708·2019-08-29 13:11
閱讀 1581·2019-08-29 12:49