Contest2381 - 【C3】周日上午比赛准备(吴)

2024-06-02 09:00:00
3333-06-02 13:00:00
运行中 公开 当前时间:2024-11-10 11:52:16

信息与公告

#include<bits/stdc++.h>
using namespace std;
int a[105][105],b[105][105];
int n;
void solve()
{    //旋转
    //(i,j)->(j,n-i+1)
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
            b[j][n-i+1]=a[i][j];
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
            a[i][j]=b[i][j];
    }
}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
            cin>>a[i][j];
    while(1)
    {  //转到合法位置
        int flag=0;
        for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=n;j++)
                //当前位置(i,j)比左边(i,j-1) 高   比下面高(i-1,j)
                if(a[i][j]<=a[i][j-1]||a[i][j]<=a[i-1][j])
                    flag=1;
        }
        if(flag==0)
        {
            for(int i=1;i<=n;i++)
            {
                for(int j=1;j<=n;j++)
                    cout<<a[i][j]<<" ";
                cout<<endl;
            }
            break;
        }
        solve();
    }
   
}