atcoder#ABC277F. [ABC277F] Sorting a Matrix
[ABC277F] Sorting a Matrix
配点 : 点
問題文
非負整数を要素とする 行 列の行列 が与えられます。 かつ を満たす整数の組 について、 の 行目 列目の要素を で表します。
に対して以下の手順を行います。
- まず、 の要素のうち であるものそれぞれを、任意の正の整数で置き換える( である要素が複数ある場合、それぞれを異なる正の整数で置き換えることもできます)。
- その後、「下記の つの操作のどちらかを行うこと」を好きな回数( 回でも良い)だけ行う。
- を満たす整数の組 を選び、 の 行目と 行目を入れ替える。
- を満たす整数の組 を選び、 の 列目と 列目を入れ替える。
- を満たす整数の組 を選び、 の 行目と 行目を入れ替える。
- を満たす整数の組 を選び、 の 列目と 列目を入れ替える。
が次の条件を満たすようにすることができるかどうかを判定してください。
- $A_{1, 1} \leq A_{1, 2} \leq \cdots \leq A_{1, W} \leq A_{2, 1} \leq A_{2, 2} \leq \cdots \leq A_{2, W} \leq A_{3, 1} \leq \cdots \leq A_{H, 1} \leq A_{H, 2} \leq \cdots \leq A_{H, W}$
- 言い換えると、 および を満たす任意の つの整数の組 と について、下記の つの条件がともに成り立つ。
- ならば
- 「 かつ 」ならば
- ならば
- 「 かつ 」ならば
制約
- 入力はすべて整数
入力
入力は以下の形式で標準入力から与えられる。
出力
が問題文中の条件を満たすようにできる場合は Yes
を、できない場合は No
を出力せよ。
3 3
9 6 0
0 4 0
3 0 3
Yes
以下の手順で操作を行うことで、 が問題文中の条件を満たすようにすることができるため、Yes
を出力します。
- まず、 の である要素を下記の通りに置き換える。
9 6 8
5 4 4
3 1 3
- 列目と 列目を入れ替える。その結果、 は下記の通りとなる。
9 8 6
5 4 4
3 3 1
- 行目と 行目を入れ替える。その結果、 は下記の通りとなる。
3 3 1
5 4 4
9 8 6
- 列目と 列目を入れ替える。その結果、 は下記の通りとなり、問題文中の条件を満たすようになる。
1 3 3
4 4 5
6 8 9
2 2
2 1
1 2
No
どのように操作を行っても が問題文中の条件を満たすようにすることはできないため、No
を出力します。