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 ...
随机推荐
- java android 环境变量配置备忘录
java android 环境变量配置备忘录,全新重装系统要用到,备忘下来; JAVA_HOME D:\Java\jdk1.6.0_07 CLASSPATH .;%JAVA_HOME%\lib\dt ...
- 4 个技巧学习 Golang
到达 Golang 大陆:一位资深开发者之旅. 2014 年夏天…… IBM:“我们需要你弄清楚这个 Docker.” 我:“没问题.” IBM:“那就开始吧.” 我:“好的.”(内心声音):”Doc ...
- 关于webpack的path和publicPath。
path:所有输出文件的目标路径; publicPath:输出解析文件的目录,url 相对于 HTML 页面 区别:path是webpack所有文件的输出的路径,必须是绝对路径,比如:output输出 ...
- phonegap 开发案例
PhoneGap-Android-HTML5-WebSocket 不使用任何框架,教你制作网页滑动切换效果 http://www.csdn.net/article/2012-04-17/2804644 ...
- jQuery 对象
jQuery 对象 版权声明:未经博主授权,严禁转载分享 什么是 jQuery 对象 jQuery 对象是通过 jQuery 包装 DOM 对象后产生的对象. jQuery 对象是一个类数组对象. j ...
- C++ 单例模式(转载)
转载:http://www.cnblogs.com/cxjchen/p/3148582.html 转载:http://blog.csdn.net/hackbuteer1/article/details ...
- JRebel for IntelliJ 热部署破解方法
1.打开idea,然后打开设置. 2.点击Plugins 3.重启之后点击 4.下载激活JRebel的插件,下载地址:https://github.com/ilanyu/ReverseProxy/re ...
- Python3基础 父,子类普通方法重名 子类方法覆盖父类方法
Python : 3.7.0 OS : Ubuntu 18.04.1 LTS IDE : PyCharm 2018.2.4 Conda ...
- I2C总线信号时序总结【转】
本文转载自:https://i.cnblogs.com/EditPosts.aspx?opt=1 I2C总线信号时序总结 总线空闲状态 I2C总线总线的SDA和SCL两条信号线同时处于高电平时,规定 ...
- Java 面向对象之static,final,匿名对象,内部类,包,修饰符
01final关键字概念 A: 概述 继承的出现提高了代码的复用性,并方便开发.但随之也有问题,有些类在描述完之后,不想被继承, 或者有些类中的部分方法功能是固定的,不想让子类重写.可是当子类继承了这 ...