#P12644. 「OOI 2021 Day 1」矩阵排序
「OOI 2021 Day 1」矩阵排序
题目描述
给定两个大小为 的表格 和 。
我们将“按列排序”定义为以下操作:选择一列,并根据该列的值对所有行进行排序,从包含较小值的行到包含较大值的行。如果两行在该列的值相同,则它们的相对顺序保持不变(这种排序称为「稳定排序」)。
这种按列排序的功能几乎可以在任何用于处理表格的办公应用程序中找到。皮特正在使用其中一款应用程序,他打开了表格 。他希望通过零次或多次按列排序操作,将表格 转换为表格 。
请确定他是否能做到这一点,如果可以,请为他提供一个操作算法——即按列排序的列序号序列。注意,不需要最小化操作次数。
输入格式
第一行包含两个整数 和 ,表示表格的尺寸。
接下来的 行,每行包含 个整数 ,定义表格 。
再接下来的 行,以相同格式定义表格 ,每行包含 个整数 。
输出格式
如果无法通过排序将表格 转换为表格 ,则输出 -1
。
否则,第一行输出一个整数 ,表示需要进行的排序次数。
接下来一行输出 个整数 ,表示需要按其排序的列序号。
可以证明,如果皮特能够实现目标,那么 次操作足够完成。
2 2
2 2
1 2
1 2
2 2
1
1
3 3
2 3 2
1 3 3
1 1 2
1 1 2
1 3 3
2 3 2
2
1 2
2 2
1 1
2 1
2 1
1 1
-1
数据范围与提示
详细子任务附加限制及分值如下表所示。其中子任务 是样例。
子任务 | 分值 | 附加限制 | 子任务依赖 | 备注 |
---|---|---|---|---|
, | ||||
表格 和 的所有列均为 到 的排列 | ||||
, | ||||
, | ||||
, | ||||
, | ||||
, |