#993. [语言月赛202210] 军训
[语言月赛202210] 军训
题目描述
某 E 刚结束军训,军训教官将所有同学排成了 行 列。
教官组织同学们进行分列式练习,同学们将按行为单位进行练习。第 行第 名同学摆臂的高度为 ,踢腿的高度为 。
教官认为,每一行同学的不整齐度为摆臂高度方差与踢腿高度方差之和。形式化的,第 行同学的不整齐度为
$$\dfrac{1}{m} \times \sum\limits_{j=1}^{m}{\Bigg(a_{i,j}-\dfrac{\sum\limits_{k=1}^{m}{a_{i,k}}}{m}\Bigg)^2} + \dfrac{1}{m} \times \sum\limits_{j=1}^{m}{\Bigg(b_{i,j}-\dfrac{\sum\limits_{k=1}^{m}{b_{i,k}}}{m}\Bigg)^2} $$其中, 代表 。
教官希望对若干行进行位置上的对调,使得最终排出的方阵中,从第 行至第 行不整齐度依次递增。若有两行不整齐度相同,可以任意安排其顺序。
请你编写程序,给出一种交换方案。请注意,每一步交换是即刻完成的。
例如,给出如下的交换方案:
第一步,交换第 行和第 行;第二步,交换第 行和第 行。
初始:
当前行数 | 初始行号 |
---|---|
第一步完成后:
当前行数 | 初始行号 |
---|---|
第二步完成后:
当前行数 | 初始行号 |
---|---|
提示:例如,将第 行与第 行交换后,原第 行将被叫做第 行,而不是仍被叫做第 行。
具体解释可参照样例 #2 解释。
输入格式
输入共 行。
输入的第一行为两个整数 ,分别代表列数和行数。
接下来 行,每行 个整数,第 行第 个代表 。
接下来 行,每行 个整数,第 行第 个代表 。
输出格式
输出若干行。
输出的第一行为一个整数 ,代表你交换方案中交换的次数。
接下来 行,每行输出两个整数 ,代表将第 行与第 行的同学进行交换。
注意: 应当不超过 。
3 3
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
1 1 1
3
1 2
1 3
2 3
3 3
3 6 9
2 4 6
1 2 3
1 1 1
1 1 1
1 1 1
3
1 2
2 3
1 2
提示
样例 #2 解释
仅考虑摆臂高度,在前两次交换后,阵列变成如下的样子:
$\begin{matrix} 1: & 2 & 4 & 6 \\ 2: & 1 & 2 & 3 \\ 3: & 3 & 6 & 9 \end{matrix}$
此时,原第 行现被叫做第 行,原第 行现被叫做第 行。如果我们想要将它们交换,应该输出 1 2
而不是 2 3
。
数据规模与约定
对于 的数据,所有 均相同, 均相同。
对于另外 的数据,满足 。
对于 的数据,。
Special Judge
本题答案不唯一,将有 Special Judge 对你的答案进行检查,所有合法答案均可以得分。
Problem Assigned by 览遍千秋 | 七海