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 ...
随机推荐
- python之路----logging模块
函数式简单配置 import logging logging.debug('debug message') #bug logging.info('info message') #信息 logging. ...
- ACM题目————困难的串
题目描述 如果一个字符串包含两个相邻的重复子串,则称他是“容易的串”,其他串称为"困难的串".例如,BB,ABCDACABCAB,ABCDABCD都是容易的串,而D,DC,ABDA ...
- SNMP学习笔记之SNMP4J介绍(Java)
0x00 SNMP4J介绍 SNMP4J是一个用Java来实现SNMP(简单网络管理协议)协议的开源项目.它支持以命令行的形式进行管理与响应.SNMP4J是纯面向对象设计与SNMP++(用C++实现S ...
- Django popup示例
urls.py urlpatterns = [ url('popup_test1',views.popup_test1), url('popup_test2',views.popup_test2), ...
- 定制django admin页面的跳转
在django admin的 change_view, add_view和delete_view页面,如果想让页面完成操作后跳转到我们想去的url,该怎么做 默认django admin会跳转到ch ...
- STL与泛型编程(第一周)
part 1 C++模版简介 一,模版概观 1.模板 (Templates)是C++的一种特性,允许函数或类(对象)通过泛型(generic types)的形式表现或运行. 模板可以使得函数或类在对应 ...
- linux虚拟机中安装vm_tool的方法及用处
解决问题:实现虚拟机VMware上linux与windows互相自由复制与粘贴.如在同一个系统下ctrl+c 与ctrl+v一样方便.解决了只能通过U盘摆渡复制的繁琐问题. 系统环境: 虚拟机VMwa ...
- Go第十篇之反射
反射是指在程序运行期对程序本身进行访问和修改的能力.程序在编译时,变量被转换为内存地址,变量名不会被编译器写入到可执行部分.在运行程序时,程序无法获取自身的信息. 支持反射的语言可以在程序编译期将变量 ...
- 骗访问量的机房人物列传by xMinh
作者:$xMinh$ 人物列传·Refun(Aufun,虚凡,人赢) 机房最人赢的人赢,上过表白墙的男人 在宿舍公然开设情感讲座和人赢培训班,教学成果显著,他的徒弟要么gay了要么凉了 认识的人极其广 ...
- CodeForces Round #516 Div2 题解
A. Make a triangle! 暴力... 就是给你三个数,你每次可以选一个加1,问最少加多少次能构成三角形 #include <bits/stdc++.h> #define ll ...