#joi2011yof. [joi2011yo_f]JOI 旗 (JOI Flag)
[joi2011yo_f]JOI 旗 (JOI Flag)
問題
情報オリンピック日本委員会では,今年の日本情報オリンピック (JOI) を宣伝するために,JOI のロゴをモチーフにした旗を作ることになった.旗は「良い旗」でなければならない.「良い旗」とは,アルファベットの J,O,I のいずれかの文字を,縦 行,横 列の長方形状に並べたもので,J,O,I が以下の図のように (すなわち,J の右隣に O が,その J の下隣に I が) 並んでいる箇所が旗の少なくとも か所にあるものである.
以下の図に,「良い旗」の例を つ示す.
以下の図に,「良い旗」ではない例を つ示す.
いま の値,および旗の一部の場所について J,O,I のどの文字にするかが決まっており,入力としてその情報が与えられる.考えられる「良い旗」は何通りあるかを計算し,その数を で割った余りを出力するプログラムを作成せよ.
入力
入力は 行からなる.
行目には旗の大きさを表す つの整数 (,) が空白で区切られて書かれている.
行目 () には, 文字からなる文字列が書かれている.各文字は J,O,I,? のいずれかであり, 文字目 () が J,O,I のいずれかである場合は 行 列の場所の文字がそれぞれ J,O,I に決まっていること,? である場合はまだ決まっていないことを表す.
出力
考えられる「良い旗」の個数を で割った余りを 行で出力せよ.
入力例 1
2 3
??O
IIJ
出力例 1
4
入力例 においては,以下の図の 通りの「良い旗」が考えられる.
入力例 2
2 2
??
??
出力例 2
3
入力例 3
3 3
??I
???
O?J
出力例 3
53
入力例 4
5 4
JOI?
????
????
????
?JOI
出力例 4
28218
入力例 においては,「良い旗」は 通り考えられるので,それを で割った余りである を出力する.