第二个点TLE,求调

P1434 [SHOI2002] 滑雪

zhangzhixuan_Retired @ 2023-10-17 21:22:42

#include<bits/stdc++.h>
using namespace std;
int m,n,a[101][101];
int x[4]={0,0,1,-1},y[4]={1,-1,0,0},max1=1,vis[101][101];
queue<int>qx,qy,qstep;
void bfs(int h,int l)
{
    qx.push(h);
    qy.push(l);
    qstep.push(1);
    while(!qx.empty())
    {
        for(int i=0;i<=3;i++)
        {
            int xx=qx.front()+x[i];
            int yy=qy.front()+y[i];
            if(xx>=1&&yy>=1&&xx<=n&&yy<=m&&a[xx][yy]<a[qx.front()][qy.front()])
            {
                qx.push(xx);
                qy.push(yy);
                qstep.push(qstep.front()+1);
                if(qstep.back()>max1) max1=qstep.back();
            }
        }   
        qx.pop();
        qy.pop();
        qstep.pop();
    }
}
int main()
{
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            scanf("%d",&a[i][j]);
        }
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            bfs(i,j);
        }
    }
    printf("%d",max1);
}

|