hdu 1226 bfs+余数判重+大数取余
题目:
超级密码
Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 4233 Accepted Submission(s):
1363
密码是一个C进制的数,并且只能由给定的M个数字构成,同时密码是一个给定十进制整数N(0<=N<=5000)的正整数倍(如果存在多个满足条件的数,那么最小的那个就是密码),如果这样的密码存在,那么当你输入它以后门将打开,如果不存在这样的密码......那就把门炸了吧.
注意:由于宝藏的历史久远,当时的系统最多只能保存500位密码.因此如果得到的密码长度大于500也不能用来开启房门,这种情况也被认为密码不存在.
注意:在给出的M个数字中,如果存在超过10的数,我们约定用A来表示10,B来表示11,C来表示12,D来表示13,E来表示14,F来表示15.我保证输入数据都是合法的.
please".
注意:构成密码的数字不一定全部都要用上;密码有可能非常长,不要试图用一个整型变量来保存密码;我保证密码最高位不为0(除非密码本身就是0).
22 10
3
7 0 1
2 10
1
1
25 16
3
A B C
give me the bomb please
CCB
Hint
Huge input, scanf is recommended.
#include<bits/stdc++.h>
using namespace std;
int num[20],n,m,c;
bool vis[5005]; //余数判重,如果之前出现过这个余数则再出现时可直接跳过,如果不这样会造成大量的重复数据!
struct node
{
char s[505];
int cur;
};
inline int mod(node tr) //大数取余
{
int i,j,tmp=0;
for (i=0;i<tr.cur;i++){
if (tr.s[i]>='0'&&tr.s[i]<='9') j=tr.s[i]-'0';
else j=tr.s[i]-'A'+10;
tmp=(tmp*c+j)%n;
}
return tmp;
}
inline void print(node tr)
{
for (int i=0;i<tr.cur;i++) printf("%c",tr.s[i]);
cout<<endl;
}
inline bool bfs()
{
queue<node> q;
int i,j;
node temp,next;
for (i=1;i<16;i++){ //选择第一位,因为不能为0所以从1开始
if (num[i]){temp.cur=0;
if (i<=9) temp.s[temp.cur++]=i+'0';
else temp.s[temp.cur++]=i-10+'A';
if (!vis[mod(temp)]){
vis[mod(temp)]=1;
if (mod(temp)==0) {print(temp);return true;}
else q.push(temp);;
}
}
}
while (!q.empty()){
next=q.front();
if (next.cur>500) break;
for (i=0;i<=15;i++){next=q.front(); //注意,要先把front()与所有的数遍历一遍之后再pop()掉
if (num[i]){
if (i<=9) next.s[next.cur++]=(char)(i+'0');
else next.s[next.cur++]=(char)(i-10+'A');
if (!vis[mod(next)]){
vis[mod(next)]=1;
if (mod(next)==0) {print(next);return true;}
else q.push(next);
}
}
}
q.pop();
}
return false;
}
int main()
{
int t,i,j;
char ch;
//char a[100];n=22;c=10;
//while (cin>>a) cout<<mod(a)<<endl;
cin>>t;
while (t--){
memset(vis,0,sizeof(vis));
memset(num,0,sizeof(num));
scanf("%d%d%d",&n,&c,&m);
for (i=1;i<=m;i++){
//cin>>ch;
getchar();scanf("%c",&ch);
if (ch>='0'&&ch<='9') num[ch-'0']=1;
else num[ch-'A'+10]=1;
}
if (n==0) {
if (num[0]==1) printf("0\n");
else printf("give me the bomb please\n");
continue;
}
if (!bfs()) printf("give me the bomb please\n");
}
return 0;
}
hdu 1226 bfs+余数判重+大数取余的更多相关文章
- poj 1465 Multiple(bfs+余数判重)
题意:给出m个数字,要求组合成能够被n整除的最小十进制数. 分析:用到了余数判重,在这里我详细的解释了.其它就没有什么了. #include<cstdio> #include<cma ...
- hdu1226 超级密码 (BFS,里面用了大数取余原理)
Problem Description Ignatius花了一个星期的时间终于找到了传说中的宝藏,宝藏被放在一个房间里,房间的门用密码锁起来了,在门旁边的墙上有一些关于密码的提示信息: 密码是一个C进 ...
- hdu 1226 超级密码(bfs+余数判重)
题意:略过 分析:用m个数字组成一个能够被n整除的c进制数的最小值,实际上本题的关键就在于这个最小值上. 首先确定我们的思路是从小到大寻找.先查看一位数,即查看着m个数字是否能被n整除:若不能,就查 ...
- hdu1664 bfs+余数判重
input n 不超过50个例子,n==0结束输入 Sample Input 7 15 16 101 0 output 最少个不同数字的n的倍数的x,若不同数字个数一样,输出最小的x Sample O ...
- 1214 - Large Division -- LightOj(大数取余)
http://lightoj.com/volume_showproblem.php?problem=1214 这就是一道简单的大数取余. 还想还用到了同余定理: 所谓的同余,顾名思义,就是许多的数被一 ...
- java大数取余
java大数取余: 类方法:BigInteger.divideAndRemainder() 返回一个数组,key = 0为商key = 1为余数 import java.util.*; import ...
- 2019计蒜之道初赛3 D. 阿里巴巴协助征战SARS(困难)(大数取余+欧拉降幂)
阿里巴巴协助征战SARS(困难) 33.29% 1000ms 262144K 目前,SARS 病毒的研究在世界范围内进行,经科学家研究发现,该病毒及其变种的 DNA 的一条单链中,胞嘧啶.腺嘧啶均 ...
- POJ2635The Embarrassed Cryptographer(大数取余+素数筛选+好题)
题目链接 题意:K是由两个素数乘积,如果最小的素数小于L,输出BAD最小的素数,否则输出GOOD 分析 素数打表将 L 大点的素数打出来,一定要比L大,然后就开始枚举,只需K对 素数 取余 看看是否为 ...
- Codeforces Round #279 (Div. 2) C. Hacking Cypher (大数取余)
题目链接 C. Hacking Cyphertime limit per test1 secondmemory limit per test256 megabytesinputstandard inp ...
随机推荐
- P4336 [SHOI2016]黑暗前的幻想乡
P4336 [SHOI2016]黑暗前的幻想乡 矩阵树定理(高斯消元+乘法逆元)+容斥 ans=总方案数 -(公司1未参加方案数 ∪ 公司2未参加方案数 ∪ 公司3未参加方案数 ∪ ...... ∪ ...
- ImageLoader作用 AAAA
https://github.com/nostra13/Android-Universal-Image-Loader ImageLoader作用 1.多线程下载图片,图片可以来源于网络,文件系统,项目 ...
- Confluence5.8部分空间名称显示为问号的解决方案
Confluence5.8部分空间名称显示为问号的解决方案 原因: 连接MySQL的时候,有没有在连接串中指定&useUnicode=true&characterEncoding=ut ...
- [省选模拟]Rhyme
考的时候脑子各种短路,用个SAM瞎搞了半天没搞出来,最后中午火急火燎的打了个SPFA才混了点分. 其实这个可以把每个模式串长度为$K-1$的字符串看作一个状态,这个用字符串Hash实现,然后我们发现这 ...
- 20145104张家明 《Java程序设计》第四次实验设计
20145104张家明 <Java程序设计>第四次实验设计 这第四次实验报告 我们开始着手安卓了 在电脑上安装了安卓虚拟机
- 20165211 获奖感想及java课程总结
20165211 获奖感想及java课程总结 理论脱离实践是最大的不幸.--达芬奇 这句话,是我在学习Java之前,假期内写的20165211 学习基础和C语言调查里的所引用的一句话,是当时我对Jav ...
- FSMC(STM32)
(一)FSMC:Flexible Static Memory Controller,可变(灵活)静态存储控制器 小容量产品是指闪存存储器容量在1 6K至32K 字节之间的STM32F101xx.STM ...
- JavaScript:new function(){}和function(){}()
继:http://www.cnblogs.com/hongdada/p/3328089.html new function(){} function(){}(): 大概的总结: function(){ ...
- hdu 3874(树状数组)题解
Problem Description Mery has a beautiful necklace. The necklace is made up of N magic balls. Each ba ...
- 阿里云Linux服务器初探
阿里云Linux服务器初探 阿里云Linux服务器初探 因为钱包的关系,本人买了一个660元2年的1核1GB的小服务器(centos是Linux的发行版),在当初是用2核4GB(内存)的时候使用的是w ...