dfs&&hdu1010奇偶剪枝

來源:互聯網
上載者:User

很神奇的剪枝條件:奇偶剪枝

用到奇偶剪枝原理:

#include<cstdio>#include<algorithm>#include<cmath>#include<queue>#include<vector>#include<string.h>#include<iostream>using namespace std;int dx[]={1,-1,0,0},dy[]={0,0,-1,1};char Map[7][7];int n,m,t;bool vis[7][7];bool ok;int ex,ey;int dis(int x,int y){ return abs(x-ex)+abs(y-ey);}void dfs(int x,int y,int step){        if(ok)return;          if(Map[x][y]=='D'&&step==t)          {            ok=1;return ;          }          if(step>=t)return;          int tmp=t-step-dis(x,y);          if(tmp<0||tmp%2)return;          for(int i=0;i<4;i++)          {           int xx=x+dx[i];           int yy=dy[i]+y;           if(xx>=0&&n>xx&&yy>=0&&yy<m&&!vis[xx][yy]&&Map[xx][yy]!='X')           {                       vis[xx][yy]=true;            dfs(xx,yy,step+1);            vis[xx][yy]=false;           }          }         }int main(){  int sx,sy,con=0;    while(cin>>n>>m>>t,n+m+t)    { con=0;ok=0;       memset(vis,false,sizeof(vis));       for(int i=0;i<n;i++)           for(int j=0;j<m;j++)           {                cin>>Map[i][j];                if(Map[i][j]=='S')                {sx=i;sy=j;vis[i][j]=1;}//剛開始忘記把起點標記已訪問wa了一次                else if(Map[i][j]=='D')                {                   ex=i;ey=j;                }                else if(Map[i][j]=='X')                {                con++;                }           }           if(n*m-con>t)           {                         dfs(sx,sy,0);           }            if(ok)                printf("YES\n");            else                 printf("NO\n");    } return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.