Problem
給定 N 盞燈,第一盞燈的所在高度 A。
Hi = (Hi-1 + Hi+1)/2 - 1
在 Hi 不低於地面高度 0 的條件下,請問最後一盞燈的高度最低為何。
Sample Input
|
|
Sample Output
|
|
Solution
二分搜尋第二盞燈的高度,推算出所有燈的高度,必且找最小高度。
|
|
給定 N 盞燈,第一盞燈的所在高度 A。
Hi = (Hi-1 + Hi+1)/2 - 1
在 Hi 不低於地面高度 0 的條件下,請問最後一盞燈的高度最低為何。
|
|
|
|
二分搜尋第二盞燈的高度,推算出所有燈的高度,必且找最小高度。
|
|
詢問區間最大值、最小值、標準差
A[l, r] = val
。A[l, r] += val
。
|
|
|
|
利用線段樹的懶操作,解決區間修改問題。
特別注意到區間的 assign
優先權高於 add
,當懶操作 assign
被指派時,取消 add
。將懶操作標記在節點 x 上,其 x 已經統計好結果,若發生要走訪 x 的子樹,將標記傳遞給子樹。
標準差的部分,可以利用 平方和 和 總和 計算之,因此紀錄總共需要四項 sum, sqr, mx, mn
來完成此題。
|
|
每個炸彈都有引爆範圍、炸彈半徑、以及炸彈所在座標。
1 : 1
。求平均花費 (引爆總花費 / 引爆次數
) 最小為何?
|
|
|
|
問平均最少花費是有原因的,如果只問最少花費只需要引爆無法被連鎖的炸彈,或者在 SCC 連通元件中找一個花費最小的炸彈。
首先,在一個連鎖反應下,先做 SCC 進行縮點,知道一個 SCC 元件中用花費最小的那個炸彈代表即可,將圖轉換成 DAG 後。indegree = 0
的點必然需要手動引爆,在這樣的情況下,已經能讓所有炸彈引爆。
為了要讓平均花費最小,勢必增加引爆炸彈的數量,引爆時便能降低平均花費,但引爆的順序必須按照拓樸排序,否則會違反 引爆過的炸彈,無法再次引爆 的規則。
藉此,根據貪心策略,將非 indegree = 0
的炸彈拿出,按照花費由小到大排序,從花費小的炸彈開始嘗試,直到平均花費無法變得更小。
選定哪個炸彈需要引爆後,仍要按照拓樸排序的方式輸出。
|
|
有 M 個人,B 個方案要進行投票表決。
每個人可以選擇 ki 個方案進行通過或不通過,其中 ki <= 4。找到一種方案的通過方式滿足所有人選擇項目的一半以上 (不含)。
|
|
|
|
由於 ki <= 4,又要滿足一半以上。則對於 ki = 1, 2 需要全部符合他們的項目。對於 ki = 3, 4 則不滿足其中一個選項 i 時,其他的選項 j 都必須滿足。
藉此套用 2-sat 模型,找到是否可能有可行解。當要輸出 2-sat 其中一解時,窮舉每一個變數為 true
/ false
,建立一條邊 x -> x'
/ x' -> x
,再用 2-sat 模型判斷是否有解即可。
找解速度會慢很多,這樣會比較好撰寫。
|
|
給予由陰陽離子構成的化合物,混和後會根據活性表發生變化,求其中一種穩定態。
所謂的穩定態,就是不會兩個化合物之間可以進行陰陽離子的互換。
|
|
|
|
一個經典的穩定婚姻問題 (stable marriage problem),可以用 Gale-Shapley algorithm 解決匹配兩邊個數相同的穩定婚姻。穩定婚姻有兩組最優解,其中一組最優解於男方、另外一組為女方,其最優解即為候選的排序為字典順序最小的。
假設現在要給男方一個最優解,那麼根據貪心的思路,男方要不斷地按照排名清單去向女方求婚,如果女方心中對求婚男方的排名更好,則男方求婚成功,而前男友就會被拋棄,被拋棄的男方將會根據清單再找下去。做法類似增廣路徑。
為什麼這樣能趨近穩定呢?原因是這樣子的,由於男方不斷地求婚,女方配對男方的排名會越來越好,男方被拋棄後,求婚對象則會越來越差。
假定男方為 A, B,女方為 1, 2,優先順序為括弧內,越靠前表示順位越高。
|
|
假如 A - 1
和 B - 2
,則女 1 更喜歡男 A,女 2 更喜歡男 B,男方中也更喜歡對方的配偶 (這個例子中是相同),而造成配對交換,這即為不穩定婚姻。
解決會交換的情況。當嘗試配對一對男女時,如何保證不會發生循環交換?當男主被某女拋棄,則表示某女心中有一個更好的某男。男方按照順序求婚,就不會發生男方中會更喜歡對方的配偶而交換。
單看女方,了解到拋棄的動作是有限的,算法就能在 O(N^2)
解決。
|
|
本篇筆記,僅為個人淺見
先了解 stream ciphers 和 block ciphers 的差異
stream ciphers 特別在於加密用的 key 不斷地變更,並且以極少數的情況下重複使用,每一次加密針對一個 byte 或者是 bit 進行加密。加解密的兩方,可以同時產生出相同 random key。
block ciphers 只用同一份 key,把加密文件一次用一個 block 文字進行加密,利用換位 (位置交換)、替換 (文字替換) … 等方式,讓相似內容的明文,可以產出差異極大的密文 (訊息獨立)。
從概念上,串流加密是絕對安全,如果雙方有辦法在不通訊下,可以產生出 random key,而且不重複使用 key,攻擊者會無從下手。但是現今很多 random 的產生方法仍然是演算法的數學模型,因此一定有規則。
而區段加密的好處,在於換位、替換、 … 等方式,將密文的相似度降低,即使明文長得很相似,攻擊者無法誘導相似明文的傳遞,導致 key 快速被發現,因為密文的差異性導致規則難以被破解。
confusion 困惑
密文跟 key 的關係盡可能混亂,根據加密的方式,有可能某些 key 會造成特殊的密文規則,這種弱 key 要不不存在、要不不使用。減少攻擊者對密文的觀察,就可以找到 key。
diffusion 散播
當明文相當相似時,也許只有幾個 bit 不同,產生出來的密文的差異性也要相當高,否則攻擊者可以推導加密原理,藉由 bitwise 將密文修改,讓解密者受到誤導。
將明文對切成兩個部分,一部分加密 subkey,另一部分根據加密過的 subkey 進行加密。在下一個回合,交換部分明文和部分密文的位置,讓所有的明文都進入到混亂狀態。
在解密時,知道 subkey 的產生規則,然後拿部分明文,加密 subkey 後,得到部分密文的加密要件,逆推回去。這一個繁複的過程,主要是製造 confusion,而 diffusion 的部分,則是在擴充 key 和拿部分明文加密 subkey 時,發生雪崩效應,因為拿部分明文進行加密 subkey,會造成 key 差異性放大。
儘管明文相似程度很高,卻會因為處理過程將差異轉移到 subkey 很多的位置的不同,經過輪替加密。無法利用頻率的方式,找到明文差異會造成密文的哪一個部分的差異。
為什麼 DES 可以被正確解密?概念上,一個密文只能對應一個明文,這樣才符合正確解密的定義。因此不同的明文,也要產生出來不同的密文。
證明從輪替下手,部分明文 A 會保留到下一個輪替,而部分明文 A 會加密部分明文 B,假設兩個明文在 A 部分不同,則在密文部分就會不同 (因為保留),假設是 B 部分不同,加密 (XOR 加密) 後也會不同。數學歸納法得證。
因為 subkey 產生方式和換位、替換的規格是明定,與 key 無關。因此 key 長短將影響加密的強度,從現在分析 56 -bit 在數個小時內就會被解出來。
為什麼 subkey 產生方式和換位、替換的規格是明定?
因為雪崩效應的造成需要某些放大效果,因此表格要符合某些設計規則。
Timing Attacks 加密時間攻擊,因為電腦運算的速度受輸入要件影響,如果 bit 變換數大,會導致加密時間拉長,藉以分析明文。
Power Attacks 偵測能源消耗,因為運算所需要的能量不同,隨著時間能到得到能源使用圖,就能分析加密過程的情況。也有為了防止這種偵測,考慮將所有運算做得一樣耗電,這有可能本末倒置。
Analytic Attacks 分析攻擊,從統計學的角度進行攻擊,從密文差異下手、從已知密文、明文解方程式、key 與加密結果的關聯性 … 等。
Electronic CodeBook (ECB),不變的 key,需要加密器和解密器,加解密的複雜度可能不同。
Cipher Block Chaining (CBC),不變的 key,以及前一個密文會先針對明文加密。
Cipher FeedBack (CFB),類似 CBC,但前一個密文的結果只影響一部分的加密關係,然後將前一段密文狀態加密 key,再對明文加密。
Output FeedBack (OFB),類似於 CFB,將前一段的加密 key 拿回來加密,不依賴接收的密文狀態。
Counter (CTR),類似於 OFB,直接利用計數器作為加密 key。
島嶼居民要建造網路連到本島,假設現在島嶼跟島嶼之間都沒有架設網路線,現在開始建造網路,使得每一個島嶼都可以與本島或者是間接相連。
請問平均等待時間需要多少。
所有的路線,在同一時刻開始建造,以每一天一公里的速度建造所有的邊,而每一條邊都以歐幾里得距離為路線長度。
|
|
|
|
一開始沒有注意到同時建造,發現這條規則後,將所有邊的長度由小到大排序,使用并查集去紀錄,找到第一個時刻連到本島的時間。
|
|
聊天室會過濾過機器人般的垃圾留言,規則如下
只要符合其中一條,訊息將無法發送,但是系統仍然會記錄下你曾經發送過的訊息,其他使用者無法看到被過濾的訊息。
|
|
|
|
這題算簡單,但是題目描述過於鬼畜。
|
|
模擬 Google 的模糊搜尋,使用編輯距離找到相符的前綴單詞數量。
編輯距離的限制小於等於 2。
|
|
|
|
對於每一個詢問,沒辦法把每一個單字都拿出來嘗試過一次。
建造一個 trie,然後在 trie 上面進行編輯距離的 dp 規則,當搜尋到重覆的結果時,可以立刻返回,由於編輯距離小於等於 2,重複走訪的可能性低很多,因此用一個懶標記,如果前綴已經符合,則下次走訪就沒有必要搜索下去。
|
|
給摩斯電碼的編碼方式,以及一串沒有切割的主字串,和可能使用的單字集,請問有多少不同的解析方式。
|
|
|
|
這題很明顯地是一道 O(nm)
的動態規劃,dp[i]
表示長度為 i 的解析方法數,藉由 match S[i, j]
轉移成 dp[j] += dp[i]
。
為了加速 match 的速度,先將字典集轉換成摩斯電碼,插入到 trie 中,當要做 match 時,相當於在 trie 走訪,可以高效地降低 O(m)
的嘗試。變成 O(nn)
|
|