POJ 3087 Shuffle'm Up bfs
题目链接:Shuffle'm Up
除了英文题有点恶心。发现模拟 + bfs 就可以过的时候,就是水了。
一个bug 就是filp函数得到string s12失败了。恩。据大腿告知,string 并不指定字符串的初始化长度是0,也就是说我每个元素的赋值是没有意义的。或者。string 是引用型数据类型,所以名字是一个指针吧。然后str.resize()函数愉快的解决了这个问题。
还有就是对题意。字符串从左到右是从下到上。我是懵了一下的。
题意思路见代码吧。
/*
题目很长。也没有看。百度到题意。给出两个长度相同的牌。洗牌方式见图得到s12。然后以最下面的相应长度为s1,上面的为s2,然后,重新洗牌。
问s12 是否有可能得到s12 和目标牌一样。步数是多少。
开始是没有思路。然后模拟。然后。bfs。把第一个s12当做初始状态,然后开始进队列。用map标记是否出现过
样例:
下 上
AHAH
HAHA
HHAAAAHH AHAH
HAHA
HAAHHAAH HAAH
HAAH
HHAAAAHH
*/ #include <string.h>
#include <iostream>
#include <queue>
#include <map>
#include <string>
#define maxn 1000000
using namespace std; queue<string>que;
map<string, int>mp;
string s1, s2, s12;
string temp, now; int ans;
int len; void filp(string s1, string s2) {
string tempans;
//cout << "======\n";
for (int i=, j=; i<len; i++, j+=) {
temp[j] = s2[i];
}
//cout << "------\n";
for (int i=, j=; i<len; i++, j+=) {
temp[j] = s1[i];
}
temp[*len] = '\0';
} void dfs() {
while(!que.empty()) {
now = que.front();
que.pop();
// cout << now << "====" << endl;
if (now == s12) {
ans = mp[now];
return;
}
for (int i=; i<len; ++i) {
s1[i] = now[i];
}
for (int i=; i<len; ++i) {
s2[i] = now[i+len];
}
filp(s1, s2);
if (!mp[temp]) {
que.push(temp);
mp[temp] = mp[now] + ;
}
}
return;
} int main() {
int t;
cin >> t;
int cnt = ;
while(t--) {
mp.clear();
ans = maxn;
cin >> len >> s1 >> s2 >> s12;
temp.resize(*len);
filp(s1, s2); mp[temp]++;
while(!que.empty()) {
que.pop();
}
que.push(temp);
dfs();
if (ans == maxn) {
cout << ++cnt << " " << - << endl;
}
else cout << ++cnt << " " << ans << endl;
dfs();
}
return ;
}
POJ 3087 Shuffle'm Up bfs的更多相关文章
- POJ.3087 Shuffle'm Up (模拟)
		
POJ.3087 Shuffle'm Up (模拟) 题意分析 给定两个长度为len的字符串s1和s2, 接着给出一个长度为len*2的字符串s12. 将字符串s1和s2通过一定的变换变成s12,找到 ...
 - POJ 3087 Shuffle'm Up(洗牌)
		
POJ 3087 Shuffle'm Up(洗牌) Time Limit: 1000MS Memory Limit: 65536K Description - 题目描述 A common pas ...
 - DFS POJ 3087 Shuffle'm Up
		
题目传送门 /* 题意:两块扑克牌按照顺序叠起来后,把下半部分给第一块,上半部给第二块,一直持续下去,直到叠成指定的样子 DFS:直接模拟搜索,用map记录该字符串是否被搜过.读懂题目是关键. */ ...
 - POJ 3087 Shuffle'm Up
		
Shuffle'm Up Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit ...
 - POJ 3087 Shuffle'm Up 线性同余,暴力 难度:2
		
http://poj.org/problem?id=3087 设:s1={A1,A2,A3,...Ac} s2={Ac+1,Ac+2,Ac+3,....A2c} 则 合在一起成为 Ac+1,A1,Ac ...
 - poj 3087 Shuffle'm Up ( map 模拟 )
		
题目:http://poj.org/problem?id=3087 题意:已知两堆牌s1和s2的初始状态, 其牌数均为c,按给定规则能将他们相互交叉组合成一堆牌s12,再将s12的最底下的c块牌归为s ...
 - POJ 3087 Shuffle'm Up (模拟+map)
		
题目链接:http://poj.org/problem?id=3087 题目大意:已知两堆牌s1和s2的初始状态, 其牌数均为c,按给定规则能将他们相互交叉组合成一堆牌s12,再将s12的最底下的c块 ...
 - POJ 3087 Shuffle'm Up DFS
		
link:http://poj.org/problem?id=3087 题意:给你两串字串(必定偶数长),按照扑克牌那样的洗法(每次从S2堆底中拿第一张,再从S1堆底拿一张放在上面),洗好后的一堆可以 ...
 - [暴力搜索] POJ 3087 Shuffle'm Up
		
Shuffle'm Up Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10003 Accepted: 4631 Des ...
 
随机推荐
- python redis基本概念简单操作
			
转自:http://www.cnblogs.com/melonjiang/p/5342383.html 一.redis redis是一个key-value存储系统.和Memcached类似,它支持存储 ...
 - UVA796 - Critical Links(Tarjan求桥)
			
In a computer network a link L, which interconnects two servers, is considered critical if there are ...
 - Jscript运行时错误:没有权限
			
问题:我在页面A中放了一个iframe ,然后在iframe 的子页面中调用主页面中的JavaScript函数,结果报错Jscript运行时错误:没有权限 原因有2: 1. 是逻辑错误,比如先关闭了i ...
 - java.util.ResourceBundle 读取国际化资源或配置文件
			
1.定义三个资源文件,放到src的根目录下面 命名规范是: 自定义名_语言代码_国别代码.properties 默认 : 自定义名.properties 2.资源文件都必须是ISO-8859-1编 ...
 - 基于Sql Server 2008的分布式数据库的实践
			
配置Sql Server 2008(Win7) 1.打开SQL server2012,使用windows身份登录 2.登录后,右键选择“属性”.左侧选择“安全性”,选中右侧的“SQL Server 和 ...
 - Word 2010文档自动生成目录和某页插入页码
			
一.Word 2010文档自动生成目录 关于Word文档自动生成目录一直是我身边同学们最为难的地方,尤其是毕业论文,经常因为目录问题,被要求修改,而且每次修改完正文后,目录的内容和页码可能都会发生变化 ...
 - nodejs Async详解之二:工具类
			
Async中提供了几个工具类,给我们提供一些小便利: memoize unmemoize log dir noConflict 1. memoize(fn, [hasher]) 有一些方法比较耗时,且 ...
 - ajax请求,html调用js
			
1:html中调用js中的函数,js使用ajax请求向后台请求,返回数据. <!DOCTYPE html> <html lang="en"> <hea ...
 - 基于struts2--实现文件上传下载
			
1. 文件的上传: 1). 表单需要注意的 3 点 ①. method="post" ②. enctype="mulitipart/form-data" ...
 - Java基础知识 Set
			
在Java中使用Set,可以方便地将需要的类型以集合类型保存在一个变量中.主要应用在显示列表.Set是一个不包含重复元素的 collection. 更确切地讲,set 不包含满足 e1.equals( ...