题目链接:

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

思路:

剪枝+回溯

这个题巧妙的是他按照表格的位置开始搜索,也就是说表格是定的,他不断用已有的图片从(0,0)开始拼到(n-1,m-1)

剪枝的地方:

1.由于含'F'的面只能拼到边上,所以'F'的个数就是矩形的周长

2.含'O'的数目应该和含'I'的数目相等

3.可能会有很多重复的碎片,如果前面的碎片不能拼上去,那么后面重复的碎片也不能拼上去

坑点:

题目中明明说了只有15块碎片,但是将数组大小开到20却WA!!,说明碎片数目已经超过15个

#include <iostream>
#include<cstring>
#include<algorithm>
using namespace std;
char maze[100][5];
int n,m;
int F=0,I=0,O=0;
int vis[100];
char loc[100][100][5];
int cmp(const void *a,const void *b){return strcmp((char*)a,(char*)b);//strcmp()不能直接判断二维数组的大小
}
int check(int cur,int i,int j){//top, right, bottom, and leftif(i==0&&maze[cur][0]!='F') return 0;if(i==n-1&&maze[cur][2]!='F') return 0;if(j==0&&maze[cur][3]!='F') return 0;if(j==m-1&&maze[cur][1]!='F') return 0;if(i>0&&(maze[cur][0]+loc[i-1][j][2]!='I'+'O')) return 0;if(j>0&&(maze[cur][3]+loc[i][j-1][1]!='I'+'O')) return 0;return 1;
}
int dfs(int x,int y,int cnt){if(cnt==n*m){//
        return 1;}char tmp[5]={0};for(int k=0;k<n*m;k++){if(!vis[k]&&(strcmp(tmp,maze[k])!=0)&&check(k,x,y)){strcpy(tmp,maze[k]);strcpy(loc[x][y],maze[k]);vis[k]=1;if(dfs((cnt+1)/m,(cnt+1)%m,cnt+1)) return 1;vis[k]=0;}}    return 0;
}
void init(){memset(maze,0,sizeof(maze));memset(vis,0,sizeof(vis));memset(loc,0,sizeof(loc));F=0,I=0,O=0;
}
int main(int argc, char** argv) {while(scanf("%d %d",&n,&m)!=EOF){if(n==0&&m==0) break;init();for(int i=0;i<n*m;i++){scanf("%s",maze[i]);for(int j=0;j<4;j++){if(maze[i][j]=='F') F++;else if(maze[i][j]=='I') I++;else if(maze[i][j]=='O') O++;}}if(F!=(m+n)*2||I!=O){printf("NO\n");}else{qsort(maze[0],n*m,sizeof(maze[0]),cmp);//q int Find=dfs(0,0,0);if(Find) printf("YES\n");else printf("NO\n");}}return 0;
}

转载于:https://www.cnblogs.com/zhuixunfighting/p/10048804.html

Puzzle (II) UVA - 519相关推荐

  1. UVa Online Judge 工具網站

    UVa Online Judge 工具網站 转自http://www.csie.ntnu.edu.tw/~u91029/uva.html Lucky貓的ACM園地,Lucky貓的 ACM 中譯題目 M ...

  2. kuangbin带你飞专题合集

    题目列表 [kuangbin带你飞]专题一 简单搜索 [kuangbin带你飞]专题二 搜索进阶 [kuangbin带你飞]专题三 Dancing Links [kuangbin带你飞]专题四 最短路 ...

  3. 算法学习经典例题整理

    陆续会对本篇博客进行更新! 搜索:https://vjudge.net/contest/292597 区间DP:https://vjudge.net/contest/293892 树状背包:https ...

  4. π-Algorithmist分类题目(1)

    原题网站:Algorithmist,http://www.algorithmist.com/index.php/Main_Page π-Algorithmist分类题目(1) Sorting UVAL ...

  5. 紫书《算法竞赛入门经典》

    紫书<算法竞赛入门经典>题目一览 第3章 数组和字符串(例题) UVA 272 TEX Quotes UVA 10082 WERTYU UVA 401 Palindromes UVA 34 ...

  6. 初学者acm的练习题指南

    上机练习题参考题 忘了在哪找的啦~~希望对大家有帮助呦 <!--[if !supportLists]-->1.    <!--[endif]-->Programming Bas ...

  7. kuangbin带你飞 专题1-23 题单

    kuangbin大神,对于打过ACM比赛的ACMer,无人不知无人不晓. 在此,附上vjudge平台上一位大神整理的[kuangbin带你飞]专题目录链接. [kuangbin带你飞专题目录1-23] ...

  8. 老鱼的-kuangbin专题题解

    kuangbin专题问题一览 专题一 简单搜索 POJ 1321 棋盘问题 POJ 2251 Dungeon Master POJ 3278 Catch That Cow POJ 3279 Flipt ...

  9. Codeforces Round #183 (Div. 2)

    A. Pythagorean Theorem II 暴力,\(O(n^2)\). B. Calendar 每个日期计算到0年1月1日的天数,相当于转化成前缀和形式. 闰年数计算\[\lfloor\fr ...

最新文章

  1. 二级联动菜单,简单实现
  2. ssl1236-逃亡准备【dp之多重背包】
  3. 【数据结构】排序算法及优化整理
  4. 撩妹学会这一招,就没有人能拒绝你!
  5. 从RSS Feed和YQL创建数据表
  6. Ubuntu安装php7.2
  7. mysql导出数据意义_11、mysql导出数据
  8. [物理学与PDEs]第1章习题7 载流线圈的磁场
  9. 计算机系统基础知识——进制转换(二进制、八进制、十进制、十六进制)
  10. 9、1.4.1 JDK下载与安装
  11. 【iOS】下的读写锁的简单实现
  12. 金蝶K3 Cloud免密登陆
  13. 最小二乘拟合问题求解算法(含python代码)
  14. 供应链金融业务如何脱颖而出?
  15. ITunes备份的背景知识
  16. php判断运营商,php识别手机号码运营商简单示例
  17. (淘宝无限适配)手机端rem布局
  18. 华为路由器联动_华为移动路由体验报告:你的随身WiFi伴侣
  19. GPS实验二:GPS接收机的使用
  20. 五分钟通俗理解自动驾驶

热门文章

  1. python——input() 的用法及扩展
  2. 在什么情况下,刘强东会丧失京东的控制权?
  3. 银行卡突然收到500万银行会监控吗?
  4. java随机星星怎么闪_canvas画随机闪烁的星星
  5. 华为手机出现android啥意思,传华为正研发手机系统,如果脱离安卓系统,还有啥能阻止华为前进...
  6. python样本不均衡_使用Python中的smote处理正负样本之间的不平衡,python,实现,失衡,问题...
  7. opencv相机标定和人头姿态估计案例
  8. PCA的原理及MATLAB实现
  9. python学习,day3:函数式编程,*arge,**kwargs
  10. 机器学习笔记(6) 线性回归