Puzzle (II) UVA - 519
题目链接:
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相关推荐
- UVa Online Judge 工具網站
UVa Online Judge 工具網站 转自http://www.csie.ntnu.edu.tw/~u91029/uva.html Lucky貓的ACM園地,Lucky貓的 ACM 中譯題目 M ...
- kuangbin带你飞专题合集
题目列表 [kuangbin带你飞]专题一 简单搜索 [kuangbin带你飞]专题二 搜索进阶 [kuangbin带你飞]专题三 Dancing Links [kuangbin带你飞]专题四 最短路 ...
- 算法学习经典例题整理
陆续会对本篇博客进行更新! 搜索:https://vjudge.net/contest/292597 区间DP:https://vjudge.net/contest/293892 树状背包:https ...
- π-Algorithmist分类题目(1)
原题网站:Algorithmist,http://www.algorithmist.com/index.php/Main_Page π-Algorithmist分类题目(1) Sorting UVAL ...
- 紫书《算法竞赛入门经典》
紫书<算法竞赛入门经典>题目一览 第3章 数组和字符串(例题) UVA 272 TEX Quotes UVA 10082 WERTYU UVA 401 Palindromes UVA 34 ...
- 初学者acm的练习题指南
上机练习题参考题 忘了在哪找的啦~~希望对大家有帮助呦 <!--[if !supportLists]-->1. <!--[endif]-->Programming Bas ...
- kuangbin带你飞 专题1-23 题单
kuangbin大神,对于打过ACM比赛的ACMer,无人不知无人不晓. 在此,附上vjudge平台上一位大神整理的[kuangbin带你飞]专题目录链接. [kuangbin带你飞专题目录1-23] ...
- 老鱼的-kuangbin专题题解
kuangbin专题问题一览 专题一 简单搜索 POJ 1321 棋盘问题 POJ 2251 Dungeon Master POJ 3278 Catch That Cow POJ 3279 Flipt ...
- Codeforces Round #183 (Div. 2)
A. Pythagorean Theorem II 暴力,\(O(n^2)\). B. Calendar 每个日期计算到0年1月1日的天数,相当于转化成前缀和形式. 闰年数计算\[\lfloor\fr ...
最新文章
- 二级联动菜单,简单实现
- ssl1236-逃亡准备【dp之多重背包】
- 【数据结构】排序算法及优化整理
- 撩妹学会这一招,就没有人能拒绝你!
- 从RSS Feed和YQL创建数据表
- Ubuntu安装php7.2
- mysql导出数据意义_11、mysql导出数据
- [物理学与PDEs]第1章习题7 载流线圈的磁场
- 计算机系统基础知识——进制转换(二进制、八进制、十进制、十六进制)
- 9、1.4.1 JDK下载与安装
- 【iOS】下的读写锁的简单实现
- 金蝶K3 Cloud免密登陆
- 最小二乘拟合问题求解算法(含python代码)
- 供应链金融业务如何脱颖而出?
- ITunes备份的背景知识
- php判断运营商,php识别手机号码运营商简单示例
- (淘宝无限适配)手机端rem布局
- 华为路由器联动_华为移动路由体验报告:你的随身WiFi伴侣
- GPS实验二:GPS接收机的使用
- 五分钟通俗理解自动驾驶
热门文章
- python——input() 的用法及扩展
- 在什么情况下,刘强东会丧失京东的控制权?
- 银行卡突然收到500万银行会监控吗?
- java随机星星怎么闪_canvas画随机闪烁的星星
- 华为手机出现android啥意思,传华为正研发手机系统,如果脱离安卓系统,还有啥能阻止华为前进...
- python样本不均衡_使用Python中的smote处理正负样本之间的不平衡,python,实现,失衡,问题...
- opencv相机标定和人头姿态估计案例
- PCA的原理及MATLAB实现
- python学习,day3:函数式编程,*arge,**kwargs
- 机器学习笔记(6) 线性回归