UVa - 11420 解題紀錄
題目: UVa - 11420 - Chest of Drawers
題目說明
d042. 11420 - Chest of Drawers - 高中生程式解題系統
Input: 每組測資有兩個整數,依序為 n
、s
,若皆小於 0 表結束。
Output: 輸出 n
個櫃子,確保剛好有 s
個櫃子是安全的所有情況數。
解題思路
動態規劃題,由於測資範圍不大,因此先算出所有情況的答案再輸出即可。
定義 dp[i][j][k]
:
- 若
k = 0
,表有i
個櫃子,j
個處於安全狀態,且最上層的櫃子沒有鎖。 - 若
k = 1
,表有i
個櫃子,j
個處於安全狀態,且最上層的櫃子有鎖。
先設定初始狀態 dp[1][0][0] = 1,因為若只有一個櫃子,且櫃子是不安全的,表示只有最上層沒有鎖的這種可能,dp[1][1][1] = 1,因為若只有一個櫃子,且櫃子是安全的,表示只有最上層是有鎖的這種可能。
對於 dp[i][j][k]
:
- 若
k = 0
,dp[i][j][0] = dp[i - 1][j + 1][1] + dp[i - 1][j][0]
,dp[i - 1][j + 1][1]
,表有i - 1
個櫃子,剛好j + 1
個是安全的,且最上層有鎖。
可思考為在最上層加上一個沒鎖的櫃子,則原本的最上層會變得不安全,情況就變為i
個櫃子,剛好j
個是安全的,且最上層沒鎖。dp[i - 1][j][0]
,表有i - 1
個櫃子,剛好j
個是安全的,且最上層沒鎖。
可思考為在最上層加上一個沒鎖的櫃子,則確保安全的櫃子數量不變,情況就變為i
個櫃子,剛好j
個是安全的,且最上層沒鎖。
- 若
k = 1
,dp[i][j][1] = dp[i - 1][j - 1][1] + dp[i - 1][j - 1][0]
,dp[i - 1][j - 1][1]
,表有i - 1
個櫃子,剛好j - 1
個是安全的,且最上層有鎖。
可思考為在最上層加上一個有鎖的櫃子,則會加入一個確定安全的櫃子,情況就變為i
個櫃子,剛好j
個是安全的,且最上層有鎖。dp[i - 1][j - 1][0]
,可思考為在最上層加上一個有鎖的櫃子,則會加入一個確定安全的櫃子,情況就變為i
個櫃子,剛好j
個是安全的,且最上層有鎖。
簡單來說就是不斷枚舉加入最上層的櫃子,若 k = 0
表示加入的沒鎖,若 k = 1
表示加入的有鎖,找出對應的關係即可。
參考解法
1 |
|
參考資料
d042. 11420 - Chest of Drawers - 高中生程式解題系統
UVa 11420 - Chest of Drawers | NaiveRed’s Blog
本部落格所有文章除特別聲明外,均採用 CC BY-NC-SA 4.0 許可協議。轉載請註明來自 Larry's notes!
評論