Submission #1295308

#TimeUsernameProblemLanguageResultExecution timeMemory
1295308ulvixTracks in the Snow (BOI13_tracks)C++20
100 / 100
532 ms209084 KiB
#include <bits/stdc++.h>
#ifdef ULVI
    #define db(x)          cerr<<"[ "<<#x<<" = "<<(x)<<" ]\n"
    #define dbv(v)         cerr<<#v<<" = [ ";for(auto &__x : v)cerr<<__x<<' ';cerr<<"]\n"
    #define line()         cerr<<string(80, '-')<<'\n'
#else
    #define db(x)
    #define dbv(v)
    #define line()
#endif
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
#define all(x) x.begin(),x.end()
#define rall(x) x.rbegin(),x.rend()
#define ff first
#define ss second
#define enld endl
using namespace std;
using namespace __gnu_pbds;
typedef long long ll;
typedef pair<ll,ll> pll;
const ll sz=2e5+100;
const ll mod=1e9+7;
const ll inf=1e18;
template<class T>
using indexed_set=tree<T,null_type,less<T>,rb_tree_tag,tree_order_statistics_node_update>;
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
ll xx[]={1,-1,0,0};
ll yy[]={0,0,1,-1};
void solve(){
    ll n,m;
    cin>>n>>m;
    vector<string> v(n+5);
    for(ll i=1;i<=n;i++){
        cin>>v[i];
        v[i]='&'+v[i];
    }
    vector<vector<ll>> dist(n+5,vector<ll>(m+5,inf));
    dist[1][1]=1;
    deque<pll> dq;
    dq.push_back({1,1});
    while(!dq.empty()){
        auto [x,y]=dq.front();
        dq.pop_front();
        for(ll i=0;i<4;i++){
            ll nx=x+xx[i],ny=y+yy[i];
            if(nx<1 || ny<1 || nx>n || ny>m) continue;
            if(v[nx][ny]=='.') continue;
            ll c=(v[x][y]!=v[nx][ny]);
            if(dist[nx][ny]>dist[x][y]+c){
                dist[nx][ny]=dist[x][y]+c;
                if(c) dq.push_back({nx,ny});
                else dq.push_front({nx,ny});
            }
        }
    }
    ll mx=0;
    for(ll i=1;i<=n;i++){
        for(ll j=1;j<=m;j++){
            if(v[i][j]=='.') continue;
            mx=max(mx,dist[i][j]);
        }
    }
    cout<<mx<<'\n';
}

int main(){
    //freopen("input.txt","r",stdin);
    //freopen("output.txt","w",stdout);
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    ll t=1;
    //cin>>t;
    for(ll _=1;_<=t;_++){
        //cout<<"Scenario #"<<_<<":\n";
        solve();
    }
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...