TC-572-D1L2 (双向搜索+记忆化)

solution:
这一题是比较难实现的双向搜索题:(字符串+双向搜索+hash记忆化)
我们可以先把K的前半部分枚举出来,并将得出的所有结果和题目给的n个数的每一个数的前半部分都比对一遍,得到它和每一个数有几位相同,并hash存到map中去。
然后我们枚举K的后半部分,并将得出的所有结果和题目给的n个数的每一个数的后半部分都比对一遍,得到它和每一个数有几位相同。这样我们可以得到:对于每一个枚举出的结果,他所对应的前半部分和n个数中每个数比对后应该有几位相同,将你得到的结果与标准值取差然后hash,看map中是否有一样的值存在。(存在就表示你找到了一个(也可能是多个)解,然后判断一下输出即可)
当然,这一题还难在细节,要仔细一点(前导零,字符串的处理,如何hash,怎样比对,分类讨论应该输出什么........)
=>
code:
#include<iostream>
#include<cstdio>
#include<iomanip>
#include<algorithm>
#include<cstring>
#include<cstdlib>
#include<ctime>
#include<cmath>
#include<vector>
#include<queue>
#include<map>
#include<set>
#define ll long long
#define db double
#define inf 0x7fffffff
#define rg register int
using namespace std;
int n,m,s,su,ans,f;
int l[11],r[55];
int b[55],a[55][11];
char ch[55];
map<int,int> h;
inline int qr(){
char ch;
while((ch=getchar())<'0'||ch>'9');
int res=ch^48;
while((ch=getchar())>='0'&&ch<='9')
res=res*10+(ch^48);
return res;
}
inline int haxi(){
unsigned int sdf=11;
for(rg i=1;i<=n;++i){
sdf=(sdf+b[i])*7+13;
}
return sdf%inf;
}
inline int bint(int i,int j){
int res=0;
for(;i<=j;++i)
res=res*10+l[i];
return res;
}
inline void yu(int t){
if(t>m){
for(rg i=1;i<=n;++i){ b[i]=0;
for(rg j=1;j<=m;++j)
b[i]+=(a[i][j]==l[j]?1:0);
if(b[i]>r[i])return ;
}
int sdf=haxi(),lkj=bint(1,m);
if(h.find(sdf)!=h.end()) h[sdf]=-1;
else h[sdf]=lkj;
return ;
}
for(rg i=0;i<=9;++i)
l[t]=i, yu(t+1);
}
inline void dfs(int t){
if(t>s){
for(rg i=1;i<=n;++i){ b[i]=0;
for(rg j=m+1;j<=s;++j)
b[i]+=(a[i][j]==l[j]);
if(b[i]>r[i])return ;
b[i]=r[i]-b[i];
}
int sdf=haxi();
if(h.find(sdf)!=h.end()){
if((su=h[sdf])<0||ans)
puts("Ambiguity"),exit(0);
else{
int lkj=bint(m+1,s);
for(rg i=m+1;i<=s;++i)su*=10;
ans=su+lkj;
}
}
return ;
}
for(rg i=0;i<=9;++i)
l[t]=i,dfs(t+1);
}
int main(){
//freopen("passwd.in","r",stdin);
//freopen("passwd.out","w",stdout);
n=qr(); s=qr(); m=s/2;
for(rg i=1;i<=n;++i){
cin>>ch;r[i]=qr();
for(rg j=1;j<=s;++j)
a[i][j]=ch[j-1]-'0';
} yu(1); dfs(m+1);
if(ans){ int su=ans;
for(rg i=1;i<=s;++i){
if(!su)printf("0");
su/=10;
}printf("%d",ans);
}
else puts("Liar");
return 0;
}
TC-572-D1L2 (双向搜索+记忆化)的更多相关文章
- Topcoder SRM 656 (Div.1) 250 RandomPancakeStack - 概率+记忆化搜索
最近连续三次TC爆零了,,,我的心好痛. 不知怎么想的,这题把题意理解成,第一次选择j,第二次选择i后,只能从1~i-1.i+1~j找,其实还可以从j+1~n中找,只要没有被选中过就行... [题意] ...
- *HDU1142 最短路+记忆化dfs
A Walk Through the Forest Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...
- [ACM_动态规划] 数字三角形(数塔)_递推_记忆化搜索
1.直接用递归函数计算状态转移方程,效率十分低下,可以考虑用递推方法,其实就是“正着推导,逆着计算” #include<iostream> #include<algorithm> ...
- 【BZOJ-3895】取石子 记忆化搜索 + 博弈
3895: 取石子 Time Limit: 1 Sec Memory Limit: 512 MBSubmit: 263 Solved: 127[Submit][Status][Discuss] D ...
- hdu3555 Bomb (记忆化搜索 数位DP)
http://acm.hdu.edu.cn/showproblem.php?pid=3555 Bomb Time Limit: 2000/1000 MS (Java/Others) Memory ...
- Codeforces Round #174 (Div. 1) B. Cow Program(dp + 记忆化)
题目链接:http://codeforces.com/contest/283/problem/B 思路: dp[now][flag]表示现在在位置now,flag表示是接下来要做的步骤,然后根据题意记 ...
- hdu 4826(dp + 记忆化搜索)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4826 思路:dp[x][y][d]表示从方向到达点(x,y)所能得到的最大值,然后就是记忆化了. #i ...
- zoj 3644(dp + 记忆化搜索)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4834 思路:dp[i][j]表示当前节点在i,分数为j的路径条数,从 ...
- loj 1044(dp+记忆化搜索)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26764 思路:dp[pos]表示0-pos这段字符串最少分割的回文 ...
随机推荐
- Arcengine效率探究之二——属性的更新(转载)
http://blog.csdn.net/lk103852503/article/details/6570748 修改一批要素的属性有多种方法,当数据量较大时,若选择不当可能会大大影响速度. 一.IR ...
- 【机器学习】Apriori算法——原理及代码实现(Python版)
Apriopri算法 Apriori算法在数据挖掘中应用较为广泛,常用来挖掘属性与结果之间的相关程度.对于这种寻找数据内部关联关系的做法,我们称之为:关联分析或者关联规则学习.而Apriori算法就是 ...
- PAT甲题题解-1048. Find Coins (25)-水
给n,m以及n个硬币 问,是否存在两个硬币面值v1+v2=m 因为面值不会超过500,所以实际上最多500个不同的硬币而已 #include <iostream> #include < ...
- C语言版本:单链表的实现
slist.h #ifndef __SLIST_H__ #define __SLIST_H__ #include<cstdio> #include<malloc.h> #inc ...
- 作业三(下)安装VS2013
VS2013 今天常识安装Microsoft Visual Studio 2013,虽然 直接在软件管家上下载,一键安装,但是还是遇到许多问题,安装过程相当的艰难,花了好多时间.但是在尝试多次后成功的 ...
- PAT 甲级 1117 Eddington Number
https://pintia.cn/problem-sets/994805342720868352/problems/994805354762715136 British astronomer Edd ...
- 提升jmeter自身性能
JMeter负载测试时使用GUI界面和较多的收集测试结果的监听器容易造成jmeter的性能瓶颈,远程测试时的控制台尤为明显.提升JMeter负载测试时性能的方法如下: 官方的解决办法:http://j ...
- 【设计模式】—— 观察者模式Observer
前言:[模式总览]——————————by xingoo 模式意图 观察者模式,也叫发布/订阅模式,从名字来说就能察觉到它的过程应该是,发布——其他人接受. 这个模式定义了对象之间的一种依赖关系,当一 ...
- Java之Set的使用场景
2.Set使用场景 API介绍: java.util.Set接口和java.util.List接口一样,同样继承自Collection接口, 它与Collection接口中的方法基本一致,并没有对Co ...
- 【bzoj2440】 中山市选2011—完全平方数
http://www.lydsy.com/JudgeOnline/problem.php?id=2440 (题目链接) 题意 求第K个不含有完全平方因子的数 Solution 没想到莫比乌斯还可以用来 ...