50求调

P1443 马的遍历

宋欣龙 @ 2024-10-23 22:10:27

#include<queue>
#include<cmath>
#include<cstdio>
#include<vector>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int N=410;
int dx[8]={-1,-2,-2,-1,1,2,2,1};
int dy[8]={2,1,-1,-2,2,1,-1,-2};
int n,m,x,y;
bool vis[N][N];
int ans[N][N];
struct edge{
    int x,y;
};
queue<edge>q;
int bfs(int a,int b){
    edge e;e.x=a;e.y=b;q.push(e);
    while(!q.empty()){
        edge st=q.front();q.pop();
        for(int i=0;i<8;i++){
            edge nx;nx.x=st.x+dx[i];nx.y=st.y+dy[i];
            if(nx.x>=1&&nx.x<=n&&nx.y>=1&&nx.y<=m&&vis[nx.x][nx.y]==0){
                vis[nx.x][nx.y]=1;
                ans[nx.x][nx.y]=ans[st.x][st.y]+1;
                q.push(nx);
            }
        }
    }
}
int main(){
    std::ios::sync_with_stdio(0);
    cin.tie(0),cout.tie(0);
    cin>>n>>m>>x>>y;
    memset(ans,-1,sizeof(ans));
    ans[x][y]=0;vis[x][y]=1;
    bfs(x,y);
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            printf("%-5d",ans[i][j]);
        }cout<<endl;
    }
    return 0;
}

by 宋欣龙 @ 2024-10-23 22:13:03

为什么开了O2后RE,没开O2的话50分?


by tengyuxuan @ 2024-11-09 22:01:55

#include <bits/stdc++.h>
using namespace std;

struct node{
    int x,y,step;
};
queue<node> q;
int n,m,sx,sy;
int mp[410][410];
int fx[]={0,-2,-2,-1,1,2,2,1,-1};
int fy[]={0,-1,1,2,2,1,-1,-2,-2};
void bfs(){
    node st;
    st.x=sx;
    st.y=sy;
    st.step=0; 
    mp[sx][sy]=0;
    q.push(st);
    while(!q.empty()){
        node bf=q.front();
        int bx,by;
        bx=bf.x;
        by=bf.y;
        for(int i=1;i<=8;i++){
            int dx,dy;
            dx=bx+fx[i];
            dy=by+fy[i];
            if(dx>=1&&dx<=n&&dy>=1&&dy<=m&&mp[dx][dy]==-1){
                node newone;
                newone.x=dx;
                newone.y=dy;
                newone.step=bf.step+1;
                mp[dx][dy]=bf.step+1;
                q.push(newone);
            } 
        }
        q.pop();
    }
}
int main(){
    cin>>n>>m>>sx>>sy;
    memset(mp,-1,sizeof(mp));
    bfs();
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            cout<<setw(5)<<mp[i][j];
        }
        cout<<endl;
    }
    return 0;
}

|