o2以后能90分,想问一下优化方法
查看原帖
o2以后能90分,想问一下优化方法
143291
真香警告AQA楼主2021/8/30 15:08
#include<bits/stdc++.h>
using namespace std;
int n,m,x,y;
int dx[8]={2,-2,2,-2,-1,1,-1,1};
int dy[8]={1,1,-1,-1,2,2,-2,-2};
int ans[401][401];
int check(int a,int b) 
{
    if(a<1||a>n||b<1||b>m)
        return 0;
    return 1;
}
void dfs(int a,int b,int sum)
{
    int nx,ny;
    ans[a][b]=sum;
    for(int i=0;i<8;i++)
	{
        nx=a+dx[i];
        ny=b+dy[i];

        if(check(nx,ny)&&(sum+1<ans[nx][ny]||ans[nx][ny]==-1))
            dfs(nx,ny,sum+1);
    }
}
int main()
{
    cin>>n>>m;
    cin>>x>>y;
    memset(ans,-1,sizeof(ans));
    dfs(x,y,0);
    for(int i=1;i<=n;i++)
	{
        for(int j=1;j<=m;j++)
            printf("%-5d",ans[i][j]);
        cout<<endl;
    }
    return 0;
}

如题

2021/8/30 15:08
加载中...