UVA 12113 Overlapping Squares

來源:互聯網
上載者:User

標籤:style   暴力   bsp   return   print   turn   include   for   mes   

https://vjudge.net/problem/UVA-12113

 

4*4 棋盤上,用6張2*2的紙 能否擺出給定形狀

 

暴力枚舉 每張紙 放在哪兒

 

#include<cstdio>#include<cstring>using namespace std;char End[5][10],start[5][9];bool ok;bool vis[9];void judge(char p[5][9]){    for(int i=0;i<5;i++)        for(int j=0;j<9;j++)            if(End[i][j]!=p[i][j]) return;    ok=true;}void dfs(int x,char p[5][9]){    if(ok) return;    judge(p);     if(x==7) return;    char tmp[5][9];    int id=0;    for(int i=0;i<3;i++)        for(int j=1;j<=5;j+=2,id++)        {            if(vis[id]) continue;            vis[id]=true;            memcpy(tmp,p,sizeof(tmp));            tmp[i][j]=tmp[i][j+2]=tmp[i+2][j]=tmp[i+2][j+2]=‘_‘;            tmp[i+1][j-1]=tmp[i+2][j-1]=tmp[i+1][j+3]=tmp[i+2][j+3]=‘|‘;            tmp[i+1][j]=tmp[i+1][j+1]=tmp[i+1][j+2]=tmp[i+2][j+1]=‘ ‘;            dfs(x+1,tmp);            if(ok) return;            vis[id]=false;        }}int main(){    int T=0;    while(1)    {        gets(End[0]);        if(End[0][0]==‘0‘) return 0;        for(int i=1;i<5;i++) gets(End[i]);        ok=false;        memset(start,‘ ‘,sizeof(start));        memset(vis,false,sizeof(vis));        dfs(1,start);        printf("Case %d: ",++T);        puts(ok ? "Yes" : "No");    }}

 

UVA 12113 Overlapping Squares

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.