这也能过属实有点糖

P1162 填涂颜色

砂の守り @ 2024-11-19 14:50:19

#include<bits/stdc++.h>
using namespace std;
int c[100][100];
int main()
{
    int n;
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            cin>>c[i][j];
            if(i==1||j==1||i==n||j==n)
            {
                if(c[i][j]==0)
                {
                    c[i][j]=-1;
                }
            }
        }
    }
    for(int i=2;i<n;i++)
    {
        for(int j=2;j<n;j++)
        {
            if(c[i][j]==0&&(c[i-1][j]==-1||c[i][j-1]==-1||c[i][j+1]==-1||c[i+1][j]==-1))
            {
                c[i][j]=-1;
            }
        }
    }
    for(int i=2;i<n;i++)
    {
        for(int j=2;j<n;j++)
        {
            if(c[i][j]==0&&(c[i-1][j]==-1||c[i][j-1]==-1||c[i][j+1]==-1||c[i+1][j]==-1))
            {
                c[i][j]=-1;
            }
        }
    }
    for(int i=n-1;i>=2;i--)
    {
        for(int j=n-1;j>=2;j--)
        {
            if(c[i][j]==0&&(c[i-1][j]==-1||c[i][j-1]==-1||c[i][j+1]==-1||c[i+1][j]==-1))
            {
                c[i][j]=-1;
            }
        }
    }
    for(int i=n-1;i>=2;i--)
    {
        for(int j=n-1;j>=2;j--)
        {
            if(c[i][j]==0&&(c[i-1][j]==-1||c[i][j-1]==-1||c[i][j+1]==-1||c[i+1][j]==-1))
            {
                c[i][j]=-1;
            }
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            if(c[i][j]==0)
            {
                c[i][j]=2;
            }
            if(c[i][j]==-1)
            {
                c[i][j]=0;
            }
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
        {
            cout<<c[i][j]<<" ";
        }
        cout<<endl;
    }
}

|