Wow! 還記得那隻會玩踩地雷的牡蠣嗎?玩踩地雷的生活是多采多姿的,很快牡蠣就發現新的問題而牠再次陷入一個困境,於是牠想起了你。(雖然說一個禮拜前你沒能幫上牠,但牠依舊對你抱有希望)
偶然的一個情況下,牡蠣進行到如左圖的盤面,留意到該盤面的右下角有一個 $2×2$ 的小方形,很明顯地我們無法再利用牡蠣的四種策略進行下去,因為剛好有 $2$ 種可能的地雷分布而且這兩種都不會使整個盤面已出現的數字造成任何矛盾情形。當然這種情況我們只能把命運交給上帝了。
不過牡蠣馬上聯想到一個問題 (玩踩地雷使牠變成一個好奇寶寶?),對於隨意給定的一個盤面,這個盤面會有多少種可能(不違背已經被翻開來的數字)的地雷分佈呢?牡蠣將這個問題交給了你。呃,更精確地說是,交給了你的程式。
輸入檔第一行有一個正整數 $T(1 ≤ T ≤ 20)$,表示接下來有 $T$ 組踩地雷盤面。每一組盤面的輸入第一行有三個正整數 $M, N, B (1 ≤ M,N ≤ 9)$。表示該盤面的寬為 $N$,高為 $M$,一共有 $B$ 個炸彈 $(1 ≤ B ≤ M×N)$。
接下來 $M$ 行每行包含 $N$ 個字元,顯示盤面的狀況。字元只有以下幾種可能:
對每一組測試資料,輸出一行訊息。該行包含一個整數 $C$,表示該盤面所有可能的地雷分布總數。你可以假設所有測試資料的答案 $1 ≤ C ≤ 10^ 8$。也就是說,對每一組踩地雷盤面,可能的地雷分佈不會超過 $10^ 8$ 組解,且至少有一組解。
原TIOJ1073 / NPSC2005決賽(prob B)
No. | Testdata Range | Score |
---|---|---|
1 | 0 | 100 |