首页 > 其他 > 详细

codeforces#1136 C. Nastya Is Transposing Matrices(找规律)

时间:2019-03-13 15:21:42      阅读:176      评论:0      收藏:0      [点我收藏+]

题意:给出两个n*m的矩阵,每次操作可以让一个正方形矩阵行列交换。问,在无限次操作下,第一个矩阵能否变成第二个矩阵

分析:先把操作限定在2*2的矩阵中。这样对角线上的元素就可以随意交换。也就是说,如果给相邻的元素随意的交换次数,那么一个长度为n的数列可以得到任何顺序。

然后把操作放大,发现不在一个对角线上的元素无论如何也是无法交换位置的。

ac代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn=505;
int num1[maxn][maxn],num2[maxn][maxn];
vector<int>ve1,ve2;
int main()
{
    int n,m;
    scanf("%d %d",&n,&m);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            scanf("%d",&num1[i][j]);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            scanf("%d",&num2[i][j]);
    for(int a=1;a<=m;a++)
    {
        ve1.clear();
        ve2.clear();
        int y=a,x=1;
        while(y>=1&&x>=1&&y<=m&&x<=n)
        {
            ve1.push_back(num1[x][y]);
            ve2.push_back(num2[x][y]);
            x++;
            y--;
        }
        sort(ve1.begin(),ve1.end());
        sort(ve2.begin(),ve2.end());
        for(int i=0;i<ve1.size();i++)
        {
            if(ve1[i]!=ve2[i])
            {
                cout<<"NO"<<endl;
                return 0;
            }
        }
    }
    for(int a=1;a<=n;a++)
    {
        ve1.clear();
        ve2.clear();
        int y=m,x=a;
        while(y>=1&&x>=1&&y<=m&&x<=n)
        {
            ve1.push_back(num1[x][y]);
            ve2.push_back(num2[x][y]);
            x++;
            y--;
        }
        sort(ve1.begin(),ve1.end());
        sort(ve2.begin(),ve2.end());
        for(int i=0;i<ve1.size();i++)
        {
            if(ve1[i]!=ve2[i])
            {
                cout<<"NO"<<endl;
                return 0;
            }
        }
    }
    cout<<"YES"<<endl;
    return 0;
}

  

codeforces#1136 C. Nastya Is Transposing Matrices(找规律)

原文:https://www.cnblogs.com/carcar/p/10523164.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!