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 left
if(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;
}
Puzzle (II) UVA - 519的更多相关文章
- GCD - Extreme (II) UVA - 11426(欧拉函数!!)
G(i) = (gcd(1, i) + gcd(2, i) + gcd(3, i) + .....+ gcd(i-1, i)) ret = G(1) + G(2) + G(3) +.....+ G(n ...
- GCD - Extreme (II) UVA - 11426 数学
Given the value of N , you will have to nd the value of G . The de nition of G is given below: G = i ...
- CodeForces 303B Rectangle Puzzle II
题意: 给定一个靠着坐标轴长为n,宽为m的矩形和 矩形中的一个点A,求在这个矩形内部一个 长宽比为a/b的小矩形,使这个小矩形的长宽尽量大使点A在小矩形内部,并且点A尽量靠近小矩形的中心 CF的思维题 ...
- Super Poker II UVA - 12298 FFT_生成函数
Code: #include<bits/stdc++.h> #define maxn 1000000 #define ll long long #define double long do ...
- GCD - Extreme (II) UVA - 11426 欧拉函数_数学推导
Code: #include<cstdio> using namespace std; const int maxn=4000005; const int R=4000002; const ...
- F - GCD - Extreme (II) UVA - 11426
Given the value of N, you will have to find the value of G. The definition of G is given below:
- GCD - Extreme (II) UVA - 11426 欧拉函数与gcd
题目大意: 累加从1到n,任意两个数的gcd(i,j)(1=<i<n&&i<j<=n). 题解:假设a<b,如果gcd(a,b)=c.则gcd(a/c,b ...
- KUANGBIN带你飞
KUANGBIN带你飞 全专题整理 https://www.cnblogs.com/slzk/articles/7402292.html 专题一 简单搜索 POJ 1321 棋盘问题 //201 ...
- LeetCode All in One题解汇总(持续更新中...)
突然很想刷刷题,LeetCode是一个不错的选择,忽略了输入输出,更好的突出了算法,省去了不少时间. dalao们发现了任何错误,或是代码无法通过,或是有更好的解法,或是有任何疑问和建议的话,可以在对 ...
随机推荐
- JavaSE09-(练手)简易学生管理系统
1.学生管理系统实现步骤 案例需求 系统主要功能如下: 添加学生:通过键盘录入学生信息,添加到集合中 删除学生:通过键盘录入要删除学生的学号,将该学生对象从集合中删除 修改学生:通过键盘录入要修改学生 ...
- Java IO流 BufferedInputStream、BufferedOutputStream的基本使用
BufferedInputStream.BufferedOutputStream的基本使用 BufferedInputStream是FilterInputStream流的子类,FilterInputS ...
- ACL 的功能、匹配原则、端口号类别
功能 1)限制网络流量.提高网络性能.例如,ACL可以根据数据包的协议,指定这种类型的数据包具有更高的优先级,同等情况下可预先被网络设备处理. 2)提供对通信流量的控制手段. 3)提供网络访问的基本安 ...
- Java获取到异常信息进行保存(非Copy)
吐槽:不知道从什么时候开始,各大博客网站的文章开始各种复制粘贴,想好好找一个解决方法,搜索出来的博客基本上千篇一律,主要是能解决问题也还行,还解决不了问题这就恶心了.... 所以被迫自己写一篇文章,然 ...
- .net MVC 微信公众号 点击菜单拉取消息时的事件推送
官方文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141016&token=&lang=zh_CN ...
- [UWP] - Adaptive Trigger Featurede的使用方法及效果
XAML代码: <Page.Resources> <!-- DataTemplate to use in the portrait layout. --> <DataTe ...
- DX关联VS
// Windows API: #include <windows.h> // C 运行时头文件,测试可能会用到 #include <stdlib.h> //standa ...
- [leetcode299] 299. Bulls and Cows
public String getHint(String secret, String guess) { /* 判断bull 是通过比较两个字符串的每一位,每次相同就删除该字符出现的次数,因为后边的 ...
- Spring事务管理?
事务管理方式: 1.编码方案,不建议使用,具有侵入性,在原有的业务代码基础上去添加事物管理代码 2.声明式事务控制,基于AOP对目标进行代理,不具有侵入性,不需要修改原来的业务代码
- [学习笔记]尝试go-micro开发微服务<第一波>
平时项目都是基于c++,lua,node, 现在打算开始自学开发微服务; 也顺带磨砺下go和docker 前期准备 1. 有golang编程基础 本系列文章是基于有golang编程基础,有过实际开 ...