Codeforces 1136C - Nastya Is Transposing Matrices

题目链接:https://codeforces.com/problemset/problem/1136/C

 

题意:

给出 $n \times m$ 的矩阵 $A,B$,你可以对其中任意某个 $k \times k$ 的子矩阵进行转置操作。

问你是否能将 $A$ 变成 $B$。

 

题解:

不管我们如何进行转置,不难发现整个矩阵的任意一条反对角线上的元素构成的集合,都是不会变的。

而我们可以进一步得出结论,对于 $A,B$ 两个矩阵,只要满足任意一条反对角线上的它们的元素构成的集合相同,就能从 $A$ 变成 $B$。

这也很好证明,因为只要我每次都选取 $2 \times 2$ 的子矩阵进行转置,必然能将任意一条反对角线上的任意两个相邻的元素交换位置,而只要能随意交换相邻元素,任意一个序列就可以变成任意的另一个序列。

 

AC代码:

#include<bits/stdc++.h>
using namespace std;
const int K=503;
int n,m;
vector<int> a[2*K],b[2*K];
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0), cout.tie(0);

    cin>>n>>m;
    for(int i=1,x;i<=n;i++) for(int j=1;j<=m;j++) cin>>x, a[i+j].push_back(x);
    for(int i=1,x;i<=n;i++) for(int j=1;j<=m;j++) cin>>x, b[i+j].push_back(x);

    bool ok=1;
    for(int k=2;k<=n+m;k++)
    {
        sort(a[k].begin(),a[k].end());
        sort(b[k].begin(),b[k].end());
        for(int i=0;i<a[k].size();i++) if(a[k][i]!=b[k][i]) ok=0;
    }
    cout<<(ok?"YES":"NO")<<'\n';
}

 

posted @ 2019-03-18 22:04  Dilthey  阅读(439)  评论(0编辑  收藏  举报