#joi2019yof. [joi2019_yo_f]座席 (Seats)
[joi2019_yo_f]座席 (Seats)
問題文
2XXX 年,世界の国は直線状に並んでいた. 個の国があり, の番号が付けられている. に対し,国 と国 が互いに隣国である.
この年の国際情報オリンピックでは,国 からは 人の選手が参加する.国際情報オリンピックの技術委員のあなたは,競技での座席表を作成する担当である.競技会場が細長いため,一列に並んだ 個の座席に選手たちを割り当てることになった.不正防止のため,同じ国の選手や隣国の選手を隣り合う席に割り当ててはならない.
選手たちを座席に割り当てる方法は何通りあるだろうか.この数は非常に大きくなる可能性があるので,それを で割った余りを求めたい.
制約
- ()
入力
入力は以下の形式で標準入力から与えられる.
出力
選手たちを座席に割り当てる方法の数を で割った余りを 行で出力せよ.
小課題
- ( 点) , ()
- ( 点) , ()
- ( 点) 追加の制約はない.
入力例 1
4
2 1 1 1
出力例 1
4
国 から参加する 人の選手を と ,国 から参加する 人の選手を ,国 から参加する 人の選手を ,国 から参加する 人の選手を で表すことにすると,選手たちを座席に割り当てる方法としては,以下の 通りの並べ方が考えられる:
- , , , ,
- , , , ,
- , , , ,
- , , , ,
入力例 2
5
1 2 3 2 1
出力例 2
0
この入力例では,条件を満たす座席表は存在しない.
入力例 3
6
1 2 3 3 2 1
出力例 3
4754
この入力例では,選手たちを座席に割り当てる方法は 通りあるため,それを で割った余りである を出力する.