HDU-1226 超级密码 (BFS+剪枝)
密
码是一个C进制的数,并且只能由给定的M个数字构成,同时密码是一个给定十进制整数N(0<=N<=5000)的正整数倍(如果存在多个满足
条件的数,那么最小的那个就是密码),如果这样的密码存在,那么当你输入它以后门将打开,如果不存在这样的密码......那就把门炸了吧.
注意:由于宝藏的历史久远,当时的系统最多只能保存500位密码.因此如果得到的密码长度大于500也不能用来开启房门,这种情况也被认为密码不存在.
入数据的第一行是一个整数T(1<=T<=300),表示测试数据的数量.每组测试数据的第一行是两个整数N(0<=N&
lt;=5000)和C(2<=C<=16),其中N表示的是题目描述中的给定十进制整数,C是密码的进制数.测试数据的第二行是一个整数
M(1<=M<=16),它表示构成密码的数字的数量,然后是M个数字用来表示构成密码的数字.两个测试数据之间会有一个空行隔开.
注意:在给出的M个数字中,如果存在超过10的数,我们约定用A来表示10,B来表示11,C来表示12,D来表示13,E来表示14,F来表示15.我保证输入数据都是合法的.
注意:构成密码的数字不一定全部都要用上;密码有可能非常长,不要试图用一个整型变量来保存密码;我保证密码最高位不为0(除非密码本身就是0).
# include<iostream>
# include<cstdio>
# include<string>
# include<queue>
# include<cstring>
# include<algorithm>
using namespace std;
struct node
{
string ans;
int val;
node(string s,int m):ans(s),val(m){}
bool operator < (const node &a) const {
if(ans.size()==a.ans.size())
return ans>a.ans;
return ans.size()>a.ans.size();
}
};
int vis[],n,m,c,num[];
int get()
{
char ch;
cin>>ch;
if(ch>=''&&ch<='')
return ch-'';
return ch-'A'+;
}
void bfs()
{
memset(vis,,sizeof(vis));
priority_queue<node>q;
for(int i=;i<m;++i){
if(num[i]==)
continue;
string s;
if(num[i]<=)
s+=num[i]+'';
else
s+=num[i]-+'A';
vis[num[i]%n]=;
q.push(node(s,num[i]%n));
}
while(!q.empty())
{
node u=q.top();
q.pop();
if(u.val==){
cout<<u.ans<<endl;
return ;
}
if(u.ans.size()>=)
continue;
for(int i=;i<m;++i){
int now=(u.val*c+num[i])%n;
if(vis[now])
continue;
string s=u.ans;
if(num[i]<=)
s+=num[i]+'';
else
s+=num[i]-+'A';
vis[now]=;
q.push(node(s,now));
}
}
printf("give me the bomb please\n");
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&c);
scanf("%d",&m);
for(int i=;i<m;++i)
num[i]=get();
sort(num,num+m);
if(n==){
if(num[]==)
printf("0\n");
else
printf("give me the bomb please\n");
continue;
}
bfs();
}
return ;
}
TLE的DFS+剪枝写法:
# include<iostream>
# include<cstdio>
# include<string>
# include<cstring>
# include<algorithm>
using namespace std;
int vis[],n,m,c,num[],flag;
string aans;
int get()
{
char ch;
cin>>ch;
if(ch>=''&&ch<='')
return ch-'';
return ch-'A'+;
}
bool is_smaller(string s1,string s2)
{
if(s1.size()<s2.size())
return true;
if(s1.size()==s2.size()&&s1<s2)
return true;
return false;
}
void dfs(string ans,int s)
{
if(ans.size()>)
return ;
if(s==){
if(!flag){
aans=ans;
flag=;
}
else{
if(is_smaller(ans,aans))
aans=ans;
}
return ;
}
//cout<<ans<<endl;
if(flag){
if(aans.size()<ans.size())
return ;
if(aans.size()==ans.size()&&ans>aans)
return ;
}
string temp=ans;
for(int i=;i<m;++i){
int ns=(s*c+num[i])%n;
if(vis[ns])
continue;
if(num[i]<=)
ans+=num[i]+'';
else
ans+=num[i]+'A'-;
vis[ns]=;
dfs(ans,ns);
vis[ns]=;
ans=temp;
}
}
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
scanf("%d%d",&n,&c);
scanf("%d",&m);
for(int i=;i<m;++i)
num[i]=get();
sort(num,num+m);
flag=;
memset(vis,,sizeof(vis));
for(int i=;i<m;++i){
//cout<<num[i]<<endl;
string ans;
if(num[i]==)
continue;
if(num[i]<=)
ans+=num[i]+'';
else
ans+=num[i]-+'A';
if(num[i]%n==){
aans=ans;
flag=;
break;
}
vis[num[i]%n]=;
dfs(ans,num[i]%n);
vis[num[i]%n]=;
}
if(!flag)
printf("give me the bomb please\n");
else
cout<<aans<<endl;
}
return ;
}
HDU-1226 超级密码 (BFS+剪枝)的更多相关文章
- hdu.1226.超级密码(bfs)
超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- HDU 1226 超级密码(BFS) (还需研究)
Time Limit:10000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Status Desc ...
- HDU 1226 超级密码(数学 bfs)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1226 超级密码 Time Limit: 20000/10000 MS (Java/Others) ...
- hdu 1226 超级密码
超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem D ...
- hdu 1226 超级密码(bfs+余数判重)
题意:略过 分析:用m个数字组成一个能够被n整除的c进制数的最小值,实际上本题的关键就在于这个最小值上. 首先确定我们的思路是从小到大寻找.先查看一位数,即查看着m个数字是否能被n整除:若不能,就查 ...
- HDOJ 1226 超级密码(bfs)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1226 思路分析:题目要求寻找一串长度不大于500的C进制的密码,且该密码需要为十进制数N的整数倍. & ...
- HDU 1226 超级密码 (搜素)
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1226 题意简单,本来是一道很简单的搜素题目. 但是有两个bug: 1.M个整数可能有重复的. 2.N可 ...
- hdu1226超级密码 bfs
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1226/ 题目大意是:寻找一个五百位之内的C进制密码,该密码是N的正整数倍,而且只能用给定的数构成密码,求这样的密 ...
- HDOJ 1226 超级密码
超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- 超级密码(bfs)
超级密码 Time Limit : 20000/10000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submis ...
随机推荐
- ACM题目————困难的串
题目描述 如果一个字符串包含两个相邻的重复子串,则称他是“容易的串”,其他串称为"困难的串".例如,BB,ABCDACABCAB,ABCDABCD都是容易的串,而D,DC,ABDA ...
- MySQL Crash Course #19# Chapter 27. Globalization and Localization
Globalization and Localization When discussing multiple languages and characters sets, you will run ...
- MySQL Crash Course #04# Chapter 7. 8 AND. OR. IN. NOT. LIKE
索引 AND. OR 运算顺序 IN Operator VS. OR NOT 在 MySQL 中的表现 LIKE 之注意事项 运用通配符的技巧 Understanding Order of Evalu ...
- 学写网页 #04# w3school
索引: HTML 输入类型 XHTML HTML5 HTML5 样式指南和代码约定 WHO 成立于 1948 年. 对缩写进行标记能够为浏览器.翻译系统以及搜索引擎提供有用的信息. code 元素不保 ...
- Shell学习笔记之shell脚本和python脚本实现批量ping IP测试
0x00 将IP列表放到txt文件内 先建一个存放ip列表的txt文件: [root@yysslopenvpn01 ~]# cat hostip.txt 192.168.130.1 192.168.1 ...
- Python入门之面向对象module,library,package之间区别
背景 Python中有一些基本的名词,很多人,尤其是一些初学者,可能听着就很晕. 此处,简单总结一下,module,library,package之间的大概区别. Python中的module的简介 ...
- wireshark不支持抓localhost/127.0.0.1的包解决方法
有些时候,测试网络应用时,为了开发方便,我们会在本机同时开启客户端和测试端,对于第三方的库来说,因为不能debug,可能需要通过抓包进行分析,今天用wireshark根据端口抓包的时候,发现怎么都下不 ...
- IDEA开发常用快捷键
以下快捷键均为初始快捷键,可以进行自定义. 查询快捷键CTRL+N 查找类 CTRL+SHIFT+N 查找文件 CTRL+SHIFT+ALT+N 查找类中的方法或变量 CIRL+B 找变量的 ...
- C# 将 Stream 写入文件
public void StreamToFile(Stream stream,string fileName) { // 把 Stream 转换成 byte[] byte[] bytes = new ...
- JavaScript:值类型 引用类型
JavaScript类型 (1)值类型:数值.布尔值.null.undefined. (2)引用类型:对象.数组.函数. 1.string var str="hongda"; v ...