Pair.cpp

【一句話題意】給出一個n*m的圖,其中數字相同的如果沒有阻礙就可以連接消除,求出最大連接數和最大連接情況下的最小連接距離
【分析】這道題是一道奇怪的暴力題,需要用正確率換時間或者加上特判,然後隨機數隨便搞搞就行了
【code】

#include<bits/stdc++.h>
#pragma GCC optimize(2)
#define R(i,s,t) for(int i=s;i<=t;i++)
#define GN(x,y) ((x)*m+(y))
using namespace std;
typedef pair<int,int> pii;
int n,m,ans,low;
char s[6][6];
void update(int p,int l) {
    if(p>ans) {ans=p; low=l;}
    else if(p==ans) low=min(low,l);
}
int cnt,vis[34000000];
void dfs(int p,int l,int state) {
    if(++cnt>1e6) return;
    if(vis[state]<=l) return;
    vis[state]=l;
    update(p,l);
    R(i,0,n-1) R(j,0,m-1) if(isdigit(s[i][j])) {
        char rec=s[i][j];
        queue<pii> q;
        q.push(make_pair(GN(i,j),0));
        bool vis[5][5]; memset(vis,0,sizeof vis);
        while(!q.empty()) {
            int cur=q.front().first,step=q.front().second;
            q.pop(); int r=cur/m,c=cur%m,rc=GN(i,j);
            if(c>0) {
                if(s[r][c-1]==s[i][j]&&(r!=i||c-1!=j)) {
                    s[r][c-1]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r,c-1));
                    s[r][c-1]=s[i][j]=rec;
                }
                if(s[r][c-1]=='*'&&!vis[r][c-1])
                    {vis[r][c-1]=true; q.push(make_pair(GN(r,c-1),step+1));}
            }
            if(c<m-1) {
                if(s[r][c+1]==s[i][j]&&(r!=i||c+1!=j)) {
                    s[r][c+1]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r,c+1));
                    s[r][c+1]=s[i][j]=rec;
                }
                if(s[r][c+1]=='*'&&!vis[r][c+1])
                {vis[r][c+1]=true; q.push(make_pair(GN(r,c+1),step+1));}
            }
            if(r>0) {
                if(s[r-1][c]==s[i][j]&&(r-1!=i||c!=j)) {
                    s[r-1][c]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r-1,c));
                    s[r-1][c]=s[i][j]=rec;
                }
                if(s[r-1][c]=='*'&&!vis[r-1][c])
                {vis[r-1][c]=true; q.push(make_pair(GN(r-1,c),step+1));}
            }
            if(r<n-1) {
                if(s[r+1][c]==s[i][j]&&(r+1!=i||c!=j)) {
                    s[r+1][c]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r+1,c));
                    s[r+1][c]=s[i][j]=rec;
                }
                if(s[r+1][c]=='*'&&!vis[r+1][c])
                {vis[r+1][c]=true; q.push(make_pair(GN(r+1,c),step+1));}
            }
        }
    }
}
int main() {
    cin>>n>>m;
    R(i,0,n-1) cin>>s[i];
    memset(vis,0x3f,sizeof vis);
    dfs(0,0,0);
    cout<<ans<<' '<<low<<endl;
    return 0;
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章