版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
基本程序題集解題報告貪心算法刪數(shù)問題首先考慮s=1時的情況,很容易知道如果只刪一個數(shù),那么若各位數(shù)字遞增則刪除最后一個數(shù),否則刪除第一個遞減區(qū)間的首字符,這樣刪除便可以得到最小的數(shù)。而對于s>1時,我們只需要重復(fù)這種操作s次,得到的操作就是所求的最小數(shù)。旅行家的預(yù)算假設(shè)現(xiàn)在在第i站,那么在這站加滿油可以到達的最遠距離是dis[i]+c*d2,如果在這個范圍內(nèi)存在一個加油站j,它的價格pri[j]<pri[i],那么只要把油加到剛好能到達j就可以了;如果在這個范圍內(nèi)不存在這樣的加油站,那么就在i加滿油,然后走到盡量遠的加油站j,如果無法走到j(luò),即最近的加油站dis[j]>dis[i]+c*d2,此時無解。線段覆蓋貪心策略為:每次選取線段右端點最小的線段,保留這條線段,并把和這條線段有公共部分的所有線段刪除。重復(fù)這個過程,直到任兩條線段之間都沒有公共部分。由于右端點最小,所以保證了所有與這條線段沒有公共部分的線段都在這條線段的右邊,且所有與這條線段有公共部分的線段兩兩之間都有公共部分。由于有公共部分的線段中,最后只能保存一條,顯然右端點越小,對后面的影響越小,這條線段應(yīng)該保留。背包問題由于每一物品是按重量拿,所以我們每次選取當(dāng)前單位重量價值最高的放入背包,直到物品取完,或背包裝滿。任務(wù)調(diào)度遲任務(wù)──調(diào)度中在規(guī)定期限后完成的任務(wù),試題要求解出最小化遲任務(wù)的罰款總和;早任務(wù)──調(diào)度中在規(guī)定期限前完成的任務(wù),最大化早任務(wù)的罰款總和正好對應(yīng)問題的解;任意一個調(diào)度可通過下述方式安排成規(guī)范形式:1.按期限遞增的順序?qū)υ缛蝿?wù)進行調(diào)度。即只要在調(diào)度中有兩個分別完成于時間K和K+1的早任務(wù)i、j且dj<di,我們就互換i和j的位置,使得任務(wù)i在交換后仍然是早的,而任務(wù)j被移到更前的位置;2.如果某個早任務(wù)X跟在遲任務(wù)Y之后,我們可以交換X和Y的位置,使得早任務(wù)先于遲任務(wù);任一調(diào)度中早任務(wù)的集合構(gòu)成了一個獨立的任務(wù)集A,因為A中任務(wù)按期限單調(diào)遞增的順序進行調(diào)度后,沒有一個任務(wù)是遲的、且A中期限為t或更早的任務(wù)個數(shù)小于等于t。顯然A集合為滿足傳遞性質(zhì)的獨立子集,而問題的解為其中罰款總和最大的一個子集。果子合并很明顯,為了讓總和最小,我們每次應(yīng)該選取最小的兩對果子將它們搬到一起。射擊競賽統(tǒng)計所有行包含的白格數(shù)從還沒有射擊格的行中選出一個白格數(shù)最少的檢查所選的行若所選行的白格數(shù)為0,則輸出無解;否則從所選行的白格中任選一個作為射擊格,并將與該格同列的另一個白格所處行的白格數(shù)減1返回到第2步,直到所有的行都有射擊格。若還有列沒有選射擊格,則在該列任選一白格作為射擊格即可任務(wù)安排分為兩步,既是先完成對A機器的安排,然后再對B機器進行安排。我們可以很容易的用貪心法安排對A的操作。應(yīng)為每一個零件對于A機器來說都是公平的,因此記錄完成當(dāng)前分配的所有工作后每個機器的完成時間(顯然初始值所有機器為0),接下來依次加入需要完成的工作,找完成時間最小的機器完成當(dāng)前的工作。而對于B機器的安排就有點麻煩了,因為每臺A機器完成操作的時間不同,不好用貪心。其實可以這樣做,首先我們把它看作是平等的。這樣對于每一個工件,它的B操作會有自己的完成時間,同樣對于每個工件的A操作也會有。于是,我們可以這樣貪心來求得最短時間,A操作中最快完成的與B操作中最慢完成的加起來,A中第二完成的與B中倒數(shù)第二完成的加起來,A中第三完成的與B中倒數(shù)第三完成的加起來,……最后取最大的就是最短時間。原因很簡單,以最小的配對為例,最小的配最大的才能使其他的配對盡量的短……最小差距首先考慮n為奇數(shù)時,顯然我們首先應(yīng)該讓他們的位數(shù)盡量接近,即一個為ndiv2,另一個為ndiv2+1,為了讓差盡量小,所以較大的數(shù)我們我們應(yīng)該取最小的ndiv2+1個數(shù),并以升序排列,較大的數(shù)我們應(yīng)該取剩下的ndiv2個數(shù),并按降序排列。而偶數(shù)就不能這樣做,一個顯然的反例就是對于1234,如果按照奇數(shù)的方法就應(yīng)該是43-12=21,顯然31-24=7<21,所以不成立。我們將算法改改,首先枚舉兩個數(shù)的最高為,最高位定下來后,再按照奇數(shù)的方法來貪心處理剩下的數(shù)字,從中取最小的值即可。分治法一元三次方程的解這一題的方法很多,因為精度要求不高的緣故,所以無論二分還是枚舉都可以過,不過在硬枚舉時,步進的精度最好選為0.001,這樣如果出現(xiàn)f(x)f(x+0.001)<=0時,無論解是什么,再取兩位后結(jié)果不會變。如果是二分法的話,需要注意的問題就是二分過程中要加修正值、計算時判斷相等關(guān)系,然后就是需要考慮精度問題。查找第k大元素利用快排的思想,我們首先將數(shù)列以某一個標(biāo)準(zhǔn)值為基準(zhǔn)將數(shù)分為兩堆,那么根據(jù)這個標(biāo)準(zhǔn)值的位置,我們可以確定我們想要的第k大數(shù)是在哪一堆中,由此我們可以,遞歸下去,在那一堆中繼續(xù)分治找。其實快排之后直接找第k大元素也可以。麥森數(shù)對于2^m-1的位數(shù)我們顯然可以利用對數(shù)的性質(zhì)很方便的求出,即為=[lg(2^m)]+1=[m*lg(2)]+1=[m*ln(2)/ln(10)]+1,對于他的末500位可以使用快速乘方實現(xiàn),即使用二分的思想,即如果求2^n,那么應(yīng)先求2^(ndiv2),于是最后我們就等效成從2不斷平方(平方過程中不斷調(diào)整——乘以2,是否乘以2根據(jù)m轉(zhuǎn)換成2進制后的序列決定),最后的到2^m,減去1即可。逆序?qū)€數(shù)首先有一個O(n^2)的算法,即枚舉所有數(shù)對,顯然是會超時的。我們可以利用歸并排序的過程,順帶的統(tǒng)計逆序隊的個數(shù)。歸并過程中,首先我們將數(shù)組分治,分別將他們排序,并統(tǒng)計他們之中的逆序隊的個數(shù),于是剩下要統(tǒng)計的即是一個數(shù)在某個數(shù)組中,另一個數(shù)在另一個數(shù)組中的逆序?qū)?,這樣由于分治的兩個數(shù)組都是有序的,于是如果當(dāng)前合并兩數(shù)組時a[i]>a[j](i為1-mid數(shù)組中的元素,j為mid-n數(shù)組中的元素),顯然a[i],a[j]為一逆序?qū)?,并且a[j]與a[i]后面的所有元素都為逆序?qū)?,于是在合并過程中,我們就可以通過O(n)的合并時間,統(tǒng)計跨組的逆序?qū)?,于是總算時間為O(nlogn),可以承受。尋找最近點對使用分治思想,我們將平面上的點用一條豎線分為左邊的與右邊的點,分別求出兩點同時在左邊或右邊的最近點對(設(shè)他們的最小值為s),然后合并,求兩點分別在左右的最近點對,這兩點一定在離豎線的s范圍之內(nèi),將這些點列出來,按y坐標(biāo)排序,可以證明如果在這些點中存在s’<s,那么其中一個點必至另一個點的臨近7個點中的一個。另外注意的就是,如果分治了只剩45個點了,其實就可以直接O(n^2)枚舉了,這樣其實更快。剔出多于括號四則運算表達式含運算符+-*/(),其優(yōu)先順序由低至高為:+-→*/→()一個括號是否作為多于括號剔出,關(guān)鍵是在于括號內(nèi)優(yōu)先級最低的運算符與左鄰括號或右鄰括號的運算符之間的運算優(yōu)先關(guān)系。在處理表達式時我們可以從最低運算符處將表達式分開,分別處理,同時對相應(yīng)的層進行括號整理,直到處理了最外層的括號為止。剔出多于括號當(dāng)且僅當(dāng)N為2的整次冪時,問題才有解,當(dāng)然解是不唯一的。這樣可以將運動員分成兩組:1,2,…,N/2和N/2+1,N/2+2,…,N。給第一組運動員安排一個比賽日程,得到一個N/2階的方陣A1;同時給第二組的運動員安排一個比賽日程,同樣會得到一個N/2階的一個方陣A2??紤]到比賽的性質(zhì),設(shè)定第I個運動員在某一天的比賽對手為第K個運動員,則第K個運動員在同一天的比賽對手必然是第I個運動員,即若有A[I,J]=K,則A[K,J]=I。因此原問題的解(一個N階方陣)可以由分解后的兩個子問題的解,合并起來。同時每一個子問題又可以按照上述的二分法分解下去,直至每個組中僅有2個運動員時為止。搜索算法皇后問題極為基本的問題,深度優(yōu)先搜索,當(dāng)n=13時一般的搜是不行的,需要加上對稱性剪枝。八數(shù)碼問題同樣極為簡單,廣度優(yōu)先搜索,必要的話,需要加上hash判重以提高速度。拼圖由于不用旋轉(zhuǎn),可以直接往上放,所以直接搜索即可。有兩種搜索策略,一個是對于當(dāng)前的map搜索第i塊放在哪,另一個是對于當(dāng)前第一個為方的格子,應(yīng)該放那一塊;這兩種在事先都應(yīng)該判斷當(dāng)前搜索是否可行。另外,后一種搜索方法好像更快。質(zhì)數(shù)方陣首先生成所有5位質(zhì)數(shù)的布爾表(顯然末尾只可能是1379),然后循環(huán),循環(huán)次序如下最后一行,與最后一列(顯然每一個只有4種情況)兩個斜行循環(huán)21,23,31,41,算出43循環(huán)12,算出剩下的埃及分?jǐn)?shù)沒有下界,數(shù)的上界也沒有,并且廣搜也行不通,所以就毫不猶豫地使用了DFSID——可變下界深搜。然后就是深搜中的實質(zhì)性優(yōu)化,關(guān)鍵的一點就是確定當(dāng)前可以填入的分母的最大值,很容易就可以算出,他應(yīng)該取剩下的分?jǐn)?shù)值的倒數(shù)的num-t+1倍(num為當(dāng)前下界,t為當(dāng)前搜到的位置)。由于不存在下界問題,再加上一些最優(yōu)性的小剪枝,這一題可以很輕松的解決。字符串變換這題大體上需要用廣搜解決,由于節(jié)點數(shù)太多,需要考慮用雙向廣搜,然后就是要注意字符串的處理。有點難度,不過不是思維上的。聰明的打字員這一題是典型的廣搜,只不過可以肯定的是,一般的廣搜肯定是不行的??紤]對規(guī)則的優(yōu)化,總共有6個規(guī)則,首先想到的優(yōu)化就是對于同一位up后不能down、down后不能up,并且left、right不能同時成對出現(xiàn)。這樣一來,我們發(fā)現(xiàn)程序的確快了一點,然而離AC還是差遠了,怎么辦?——考慮對up與down的優(yōu)化:我們發(fā)現(xiàn),一旦一個數(shù)的位置一確定,那么對他的up或者down的操作無論在何時進行都可以(只要在操作過程中光標(biāo)經(jīng)過了這個位置)。所以,我們可以先撇開up與down不管,先廣搜一遍,對于每一個節(jié)點的操作只進行另外4種操作,同時只記錄光標(biāo)經(jīng)過了那么些位置、每個數(shù)的當(dāng)前位置在那里、以進行的操作數(shù)與光標(biāo)當(dāng)前位置。最后對于所有可能的節(jié)點加上所需up或down的操作數(shù),取最優(yōu)解即可。這樣做有一個好處,就是廣搜時可用hash標(biāo)進行判重,我們開始可以用123456代替每一個位置上的數(shù),并且光標(biāo)經(jīng)過的位置只會有10種情況(注意它是從1開始移動,根據(jù)規(guī)則它只可能有10種情況),于是判重時hash表的size只有6*6!*10=43200,完全可以承受。實際操作時,最后可能到達的節(jié)點總數(shù)只有8000多。01序列現(xiàn)在我沒有什么好方法,所以只有搜索。使用深度優(yōu)先搜索,邊搜邊判斷是否滿足要求,為加快速度,可以考慮在判斷長度比較小的序列時將它們對應(yīng)的01序列轉(zhuǎn)換為十進制數(shù),以便hash判重。、另外的一個注意之處就是,第一位添1與添0方案數(shù)是一樣的。生日蛋糕這一題可以用DP做,不過我認為是一個不明智的做法,因為此舉浪費空間大,而重疊的子問題很少,因該用搜索加以適當(dāng)?shù)膬?yōu)化來解決。首先我們就有兩個直觀的優(yōu)化:切到當(dāng)前層時表面積比最小的面積大,可以剪枝;如果剩下的體積,比可能切出的最小體積小,最大體積大,剪枝。其實這些就夠了,但是還可以進一步優(yōu)化:對于當(dāng)前的lefts(剩下的需加上的面積),有Lefts=∑(k=i+1tom)2*Rk*hk>=∑(k=i+1tom)2*Rk^2*hk/Ri=2/Ri*(N-T)=PT為已經(jīng)是已經(jīng)使用的體積,W為已經(jīng)用的面積,S為當(dāng)前最小的面積,如果P>=S-W那么可以剪枝。圖論算法一筆畫問題判斷依據(jù)為:(1)當(dāng)且僅當(dāng)一幅圖是相連的(只要你去掉所有度數(shù)為0的點)且每個點的度都是偶數(shù),這幅圖有歐拉回路.(2)當(dāng)且僅當(dāng)一幅圖是相連的且除兩點外所有的點的度都是偶數(shù).(3)在第二種情況中,那兩個度為奇數(shù)的節(jié)點一個為起點,剩下的一個是終點.求路徑時,任取一個起點(本題應(yīng)該是取編號最小的合法起點),開始下面的步驟如果該點沒有相連的點,就將該點加進路徑中然后返回。如果該點有相連的點,就列一張相連點的表然后遍歷它們直到該點沒有相連的點。(遍歷一個點,刪除一個點)處理當(dāng)前的點,刪除和這個點相連的邊,在它相鄰的點上重復(fù)上面的步驟,把當(dāng)前這個點加入路徑中。Car的旅行路線主思想就是dijkstra,因為總共最多有100個城市,所以我們就可以建400個點,然后建一個源點與A中點相連,一個匯點與B中點相連,相連的邊權(quán)值為0,然后dijkstra求解即可。只不過需要注意的是知道矩形的三個頂點如何求第四個點的問題,這其實很簡單,找到三個點中處于中間的那個點,然后用旁邊兩點的橫縱座標(biāo)的和減去他的橫縱坐標(biāo)即可。求割點與橋DFS,NUM[I]記錄訪問到I的時間戳,LOW[I]=MIN{NUM[I],LOW[Q]}存在I-Q的邊且Q不是I的父節(jié)點。然后就可以判斷了,i是割點當(dāng)i是根節(jié)點且它有2個以上的兒子,或者它不是根節(jié)點且low[q]>=num[q];(i,q)是橋當(dāng)且僅當(dāng)low[q]>num[i]。十字繡將正面的邊視為正邊,反面的則視為負邊。用floodfill將由正邊和負邊交替連接的結(jié)點組成一個塊。對于每一個塊,其中的所有結(jié)點的正邊數(shù)目和負邊數(shù)目之差的絕對值(定為dep)之后div2后就為這個塊的所需針數(shù)。在一個塊中只用一針就可完成,假設(shè)該針由v1出發(fā),到vn結(jié)束,那么v1到vn中間的點的dep為0,而v1和vn則為1。也就是說塊中的那一針在v1有一個入口,在vn有一個出口,而每一對入口和出口就代表了一針,那么就可以通過dep之和除以2得到所需針數(shù)。由此可以拓寬到多針。舞會顯然,這一體應(yīng)該是求有向圖的強連同分量的個數(shù)。求一個有向圖的強連同分量是DFS的經(jīng)典應(yīng)用,一般步驟如下:對于圖G,首先進行一次DFS,記下每個節(jié)點搜索過程中的完成時刻;將G中的所有邊反向,得到圖G的轉(zhuǎn)置,記為Gt;按照第一次DFS中節(jié)點完成時刻的遞減順序考慮圖Gt,對其進行搜索;對于第二次深搜得到的森林,每棵樹各自獨立的成為一強連通分量。休息中的小呆這一題有兩問,第一問即是求圖的最長路徑,不能使用類似dijkstra的算法解決,因為最長路徑不符合dijkstra那種最優(yōu)子結(jié)構(gòu),應(yīng)該使用bellman-ford(即對每條邊松弛n輪)。第二問其實就是求所有最長路徑上的所有點,可以考慮以劇情終點為起點做一次最長路徑,只不過起點一開始的dis[s]=-maxlen(maxlen即為第一問的結(jié)果),這樣,所有點對應(yīng)都有兩個值,如果這兩個值加起來=0,那么這個點就應(yīng)該在第二問中輸出。最有布線問題顯然是求一個圖的最小生成樹,由于每兩點都有一個距離,為一稠密圖,這里最好使用Prime,krukal在此可能效率不高。磁盤碎片整理每個碎片都有一個起始位置與目標(biāo)位置,從一個不在目標(biāo)位置上的磁盤碎片開始,一直找下去,可以找到一個環(huán),那么將他們歸位的操作次數(shù)應(yīng)該是環(huán)中節(jié)點數(shù)+1。找到所有環(huán),并逐個累加即可。說謊島注意到有可能在所有的話中,一旦某一句話的真假已經(jīng)確定,那么另一些話就已經(jīng)確定了??紤]到這種關(guān)系,我們發(fā)現(xiàn)其實這是一個圖,對于這一個圖,邊有如下定義:對于兩個問題必須同是同否,那么他們的邊權(quán)值就為1;若必須相對立,則為-1;若沒關(guān)系則為0。那么我們發(fā)現(xiàn),對于這個圖,如果他有解,那么設(shè)其連通分量數(shù)為t,則結(jié)果的中數(shù)應(yīng)為2^t,于是剩下的事情就只剩下如何判斷無解了??紤]對這個圖深搜,那么每次從一個未標(biāo)記的點開始,那么這一次搜得的結(jié)果應(yīng)該為一個兩通分量,并且同時我們可以將它里面所有的點分為兩類。這兩類應(yīng)該相互對立:一類如果為是,則另一類必為否。所以搜完一遍后,我們要進行檢查,首先檢查兩類是否有交集,然后檢查屬于同一類卻應(yīng)該相互矛盾的或?qū)儆诓煌惖膮s應(yīng)該相互關(guān)聯(lián)的情況。檢查完后,我們就可以計算,不過考慮到t較大,所以應(yīng)該用高精度。01串問題對于滿足要求的串而言,若num[i]表示串的長度為i的前綴中包含1的個數(shù),那么有0<=num[i+1]-num[i]<=1A1<=num[i+L1]-num[i]<=B1A0<=(i+L0-num[i+L0])-(i-num[i])<=B0有如上關(guān)系,我們很快發(fā)現(xiàn),他就等同于一個差分約束系統(tǒng),對于此圖,如果存在負權(quán)回路,那么他就無解,如果不存在,那么求出最短路徑,根據(jù)路徑直接構(gòu)出一組解。具體實現(xiàn)時,用bellman-ford就可以了。海島地圖這是一個典型的flood-fill(即種子填充算法)問題,既可以使用DFS,又可以使用BFS實現(xiàn),但為了保證不堆棧溢出,我們最好使用BFS。數(shù)學(xué)問題數(shù)的劃分據(jù)經(jīng)典的Ferrers圖像可以知道n拆分為k個整數(shù)的拆分?jǐn)?shù),與n拆分成最大數(shù)為k的拆分?jǐn)?shù)相等,于是用遞推的方法:用表示把b做任意剖分,其中最大的一個部分恰好是a的方案總數(shù)。用表示把b做任意剖分,其中最大的一個部分不大于a的方案總數(shù)。那么,有:。消去,有:。我們可以按照a、b遞增的順序計算的值,這樣在在計算的時候,和都已經(jīng)得到,故我們只用進行一次簡單的加法運算即可。最后的即為所求。最優(yōu)分解方案為了使最后分解的數(shù)的乘積最大,首先我們應(yīng)該確定n應(yīng)該分解為幾個數(shù)(其實就是n可以分出的最多個數(shù)),確定過程就是從2開始以步差為1累加,直到恰好小于n位置(就是找最大數(shù)為k,使2+3+…+k=t<n,劃分成的個數(shù)應(yīng)該為k+1);確定下來后,由于n剩下來了一些,所以將這些平均的加到k-2上,由于不能平分,所以應(yīng)該是先所有數(shù)加上(n-t)divk,然后較大的(n-t)modk個數(shù)多加一個1。這樣就確定下來了所有的數(shù)。我們最后使用單精度將他們乘起來即可。出棧序列統(tǒng)計每一次操作僅有兩種,即壓棧與退棧,這種操作可以對應(yīng)于一個數(shù)的中序遍歷(即向下更深層遍歷與回溯)。顯然對于答案,其實就是一個Cartlan數(shù)列,F(xiàn)(n)=C(2n,n)/(n+1)百事世界杯之旅對于要在剩下的i種瓶蓋中收集到一種,買一瓶飲料收集到的概率為(i/n),所以平均應(yīng)該買(n/i)瓶,所以平均總共要買n(1/1+1/2+1/3+….+1/n)瓶。電子鎖n-1在一起,至少缺少一種開鎖的密碼特征,故不能打開電子鎖,剩下的m-(n-1)個人中的任意一個人到場即可開鎖,所以至少有C(m,m-n+1)種特征。對于任意一個工作人員來說,其余m-1個人中的n-1個人到場,至少缺少一個這個工作人員磁卡上所具有的特征,所以每個人至少有C(m-1,n-1)種開鎖的密碼特征。對于每一種特征的分配方案,其實就是一個C(m,m-n+1)個中選擇C(m-1,n-1)的組合生成。堆塔問題對于這一題我們采用分類計數(shù)法,當(dāng)列數(shù)為i時,每一個堆塔方案對應(yīng)方程:x1+x2+x3+x4+…+xi=n的一個組正整數(shù)解,所以此時的方案數(shù)為C(n-1,i-1),所以總方案數(shù)為:C(n-1,0)+C(n-1,1)+…+C(n-1,n-1)=2^n取數(shù)游戲首先模擬取數(shù),我們要做的就是判斷無解的情況。假設(shè)某一趟共取m次,那么把每一堂取數(shù)中每一次所取的數(shù)加起來所對應(yīng)的二進制數(shù)為(11…11)2,其中1的個數(shù)為m,而取得的余數(shù)一定不大于二進制數(shù)(11…11)2,其中1的個數(shù)為m,否則可以繼續(xù)取下去。所以一個數(shù)經(jīng)過一趟取數(shù)后余下的數(shù)最多只能達到他的一半。即第i趟取數(shù)后,余下的數(shù)不超過k+n/p-k/q,這里的p等于2的i次方,q等于2的i-1次方。顯然所有的余數(shù)不會超過k+n/2,所以在取了k+n/2+1趟后尚未取完,那么必有兩趟余數(shù)相同,即永遠也取不完了。球迷購票其實這一與出棧序列統(tǒng)計類似,其實就是一個從(0,0)走到(m,n),每次只能向右或上走單位1距離,其中向上走的布數(shù)應(yīng)非嚴(yán)格大于向右走的步數(shù)的總路徑數(shù)。這個數(shù)是一個很經(jīng)典的組合數(shù),即為C(m+n,n)-C(m+n,n-1)。Fibonacci公約數(shù)可以證明GCD(Fn,Fm)=Fgcd(m,n)(只用證F(n)整除F(k*n))。傳球問題與磁盤碎片整理相似,我們首先找環(huán),每個環(huán)所需的歸位次數(shù)為環(huán)所包含節(jié)點數(shù)-1。對于總時間,我們單獨的考慮每個環(huán),最后取最大值即可。若包含節(jié)點數(shù)為1,那么需時間0;若包含節(jié)點數(shù)2,那么需時間1;若包含節(jié)點數(shù)大于2,我們可以花時間1,將此環(huán)拆成多個長度為1與2的環(huán),然后再交換,所以用時為2。約瑟夫問題顯然答案為2*(n-2^a)+1,a為使2^a不大于n的最大整數(shù)。青蛙過河有f[i,j]表示i片葉子,j塊石頭最多將青蛙送到對岸的個數(shù),那么有f[i,j]=2*f[i-1,j],其原因與漢諾塔的原理相類似(將第i個石頭看作是對岸就可以了)。而f[0,j]=j+1,應(yīng)為只有將j個石頭占滿,然后將第j+1個青蛙放到對岸,那么所有的j+1個青蛙就可以過河了。于是又f[i,j]:=(j+1)*2^n,答案即為(m+1)*2^n。棋盤游戲通過找規(guī)律我們發(fā)現(xiàn):1.無論移動什么棋子,以每一次換顏色為界,每次移動數(shù)目為1,2,3……n,n,n……,3,2,12.第一次移動白色棋子,最后一次也是的。數(shù)據(jù)結(jié)構(gòu)火車棧有一個最基本的方法,即使如果存在進棧時為i<j<k的三元組,其出棧序列為k<i<j,那么肯定它是無解的,其他情況時有解的。于是我們很快就可以得到一個O(n^3)的算法,但是很顯然——TLE。想到Cartlan樹中進棧出棧的對應(yīng)方法,我們可以按照這棵樹的生成法來檢測出棧序列。——相當(dāng)于已知一棵樹的中序遍歷,判斷一個序列是否為這棵樹的前序遍歷。這是用分治法解決。——這樣就可以解決這一題了。然而,其實有更好更簡單的方法。模擬進棧出棧,在棧頂元素與當(dāng)前要求出棧的元素相同時我就進行彈棧操作,否則就壓棧。如果無法壓棧,而且無法彈棧,那么就是無解的。如此進行硬性的掃描模擬就夠了,復(fù)雜的為O(n)。括號表達式建立一個棧,然后往里面放括號——碰見左括號就進棧,右括號就退棧,如果碰見括號不匹配,或者無法退棧的情況就是無解的。銀河英雄傳說用并查集來解決這一道問題,然而考慮到此題的特殊情況,我們要對并查集的結(jié)構(gòu)進行一定的改進然后再運用到程序中。定義以下幾個量:father[i]表示i現(xiàn)在從屬于哪一艦隊behind[i]表示i現(xiàn)在離艦首的距離dep[i]表示i后面有多少只軍艦于是,我們可以利用路徑壓縮(findfather)的過程同時進行更新dep與behind,對于路徑壓縮我們采用以下過程:functionfind(x:longint):longint;vari,j,f,temp:longint;beginf:=x;whilefather[f]<>fdof:=father[f];i:=x;whilei<>fdobegintemp:=father[i];father[i]:=f;j:=temp;repeatbehind[i]:=behind[i]+behind[j];j:=father[j];untilfather[j]=j;i:=temp;end;find:=f;end;而對于merge操作,我們要做的就是把一方的father指向另一方,同時變更behind與dep:proceduremerge(x,y:longint);varfx,fy:longint;beginfx:=find(x);fy:=find(y);father[father[fx]]:=fy;behind[fx]:=behind[fx]+dep[fy];dep[fy]:=dep[fy]+dep[fx];end;相對于find與merge,count就簡單得多,因為它只需要判斷兩艦是否屬于同一隊,然后兩個behind相減即可:procedurecheck(x,y:longint);varfx,fy:longint;beginfx:=find(x);fy:=find(y);iffx<>fythenwriteln(-1)elsewriteln(abs(behind[x]-behind[y])-1);end;矩形覆蓋
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 寒露文化傳承與應(yīng)用模板
- 小學(xué)數(shù)學(xué)《分?jǐn)?shù)除法》50道應(yīng)用題包含答案
- DB2201T 60-2024 西餐廳服務(wù)規(guī)范
- 職業(yè)導(dǎo)論-房地產(chǎn)經(jīng)紀(jì)人《職業(yè)導(dǎo)論》深度自測卷1
- 親子活動主持詞
- 二零二五年度船舶運輸代理合同
- 人教版四年級數(shù)學(xué)上冊寒假作業(yè)(九)(含答案)
- 上海市竹欣中學(xué)2024-2025學(xué)年七年級上學(xué)期英語期末測試卷(含答案無聽力原文及音頻)
- 重慶市第一中學(xué)2024-2025學(xué)年高三上學(xué)期12月月考生物試題(有答案)
- 燕山大學(xué)《數(shù)字信號處理》2023-2024學(xué)年第一學(xué)期期末試卷
- 高中歷史教學(xué)中開展小組合作學(xué)習(xí)的思考
- 監(jiān)理資料檔案盒背脊貼紙
- 數(shù)學(xué)八下學(xué)霸電子版蘇教版
- SQL Server 2000在醫(yī)院收費審計的運用
- 《FANUC-Oi數(shù)控銑床加工中心編程技巧與實例》教學(xué)課件(全)
- 微信小程序運營方案課件
- 陳皮水溶性總生物堿的升血壓作用量-效關(guān)系及藥動學(xué)研究
- 安全施工專項方案報審表
- 學(xué)習(xí)解讀2022年新制定的《市場主體登記管理條例實施細則》PPT匯報演示
- 好氧廢水系統(tǒng)調(diào)試、驗收、運行、維護手冊
- 五年級上冊口算+脫式計算+豎式計算+方程
評論
0/150
提交評論