hdu 1226
超级密码
Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 2142 Accepted Submission(s): 675
密码是一个C进制的数,并且只能由给定的M个数字构成,同时密码是一个给定十进制整数N(0<=N<=5000)的正整数倍(如果存在多个满足条件的数,那么最小的那个就是密码),如果这样的密码存在,那么当你输入它以后门将打开,如果不存在这样的密码......那就把门炸了吧.
注意:由于宝藏的历史久远,当时的系统最多只能保存500位密码.因此如果得到的密码长度大于500也不能用来开启房门,这种情况也被认为密码不存在.
注意:在给出的M个数字中,如果存在超过10的数,我们约定用A来表示10,B来表示11,C来表示12,D来表示13,E来表示14,F来表示15.我保证输入数据都是合法的.
注意:构成密码的数字不一定全部都要用上;密码有可能非常长,不要试图用一个整型变量来保存密码;我保证密码最高位不为0(除非密码本身就是0).
Hint
Huge input, scanf is recommended.
#include<iostream>
#include<stdio.h>
#include<cstring>
#include<cstdlib>
#include<queue>
#include<algorithm>
using namespace std; struct node
{
char num[];
int len;
};
queue<node>Q;
bool use[],hash[];
int n,c,m; int zc(node n1)
{
int i,mod=,k;
for(i=;i<=n1.len;i++)
{
if(n1.num[i]>=''&&n1.num[i]<='')
k=n1.num[i]-'';
else k=n1.num[i]-'A'+;
mod=(mod*c+k)%n;
}
return mod;
}
void print(node n1)
{
int i;
for(i=;i<=n1.len;i++)
printf("%c",n1.num[i]);
printf("\n");
}
int bfs()
{
int i,k;
struct node t,cur; for(i=;i<;i++)
{
if(use[i]==true)
{
t.len=;
if(i<=)
t.num[]=i+'';
else t.num[]=i-+'A';
k=i%n;
if(k==)
{
if(i==)continue;
if(i>=)printf("%c\n",i-+'A');
else printf("%c\n",i+'');
return ;
}
else if(hash[k]==false)
{
hash[k]=true;
Q.push(t);
}
}
}
while(!Q.empty())
{
t=Q.front();
Q.pop();
if(t.len>=)continue;
for(i=;i<;i++)
{
if(use[i]==true)
{
cur=t;
cur.len++;
if(i>=)
cur.num[cur.len]=i+'A'-;
else cur.num[cur.len]=i+''; k=zc(cur);
if(k==)
{
print(cur);
return ;
}
else if(hash[k]==false)
{
Q.push(cur);
hash[k]=true;
}
}
}
}
return -;
}
int main()
{
int T,i,k;
char cur[];
scanf("%d",&T);
while(T--)
{
scanf("%d%d%d",&n,&c,&m);
memset(use,false,sizeof(use));
memset(hash,false,sizeof(hash));
while(!Q.empty())
{
Q.pop();
}
for(i=;i<=m;i++)
{
scanf("%s",cur);
if(cur[]>='' && cur[]<='')
use[cur[]-'']=true;
else if(cur[]>='A')
use[cur[]-'A'+]=true;
}
if(n==)//!!!(⊙o⊙)…
{
if(use[]==true)
{
printf("0\n");
}
else printf("give me the bomb please\n");
}
else
{
k=bfs();
if(k==-)printf("give me the bomb please\n");
}
}
return ;
}
hdu 1226的更多相关文章
- HDU 1226 超级密码 (搜素)
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=1226 题意简单,本来是一道很简单的搜素题目. 但是有两个bug: 1.M个整数可能有重复的. 2.N可 ...
- hdu 1226 BFS + bfs记录路径
http://acm.hdu.edu.cn/showproblem.php? pid=1226 为了节省空间.您可以使用vis初始化数组初始化-1. 发现BFSeasy错了地方 始一直WA在这里:就是 ...
- HDU 1226 超级密码(数学 bfs)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1226 超级密码 Time Limit: 20000/10000 MS (Java/Others) ...
- hdu.1226.超级密码(bfs)
超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- hdu 1226 超级密码(bfs+余数判重)
题意:略过 分析:用m个数字组成一个能够被n整除的c进制数的最小值,实际上本题的关键就在于这个最小值上. 首先确定我们的思路是从小到大寻找.先查看一位数,即查看着m个数字是否能被n整除:若不能,就查 ...
- HDU 1226 BFS
注意密码位数<=500 输出注意十六进制改成字母 要点题目都已说明 ac就好 #include<iostream> #include<stdio.h> #include& ...
- hdu 1226 超级密码
超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Problem D ...
- hdu 1226 bfs+余数判重+大数取余
题目: 超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- hdu 1226(同余搜索)
超级密码 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
随机推荐
- gdb的调试常用命令
一.gdb常用的命令 list l 常看源代码 break b 设置断点 b 10(行号) b ...
- 974. Subarray Sums Divisible by K
Given an array A of integers, return the number of (contiguous, non-empty) subarrays that have a sum ...
- Organising the Organisation(uva10766)(生成树计数)
Input Output Sample Input 5 5 2 3 1 3 4 4 5 1 4 5 3 4 1 1 1 4 3 0 2 Sample Output 3 8 3 题意: 有一张图上有\( ...
- 弦论(tjoi2015,bzoj3998)(sam(后缀自动机))
对于一个给定长度为\(N\)的字符串,求它的第\(K\)小子串是什么. Input 第一行是一个仅由小写英文字母构成的字符串\(S\) 第二行为两个整数\(T\)和\(K\),\(T\)为0则表示不同 ...
- jzoj5894
先前綴和一發,問題表示求[0-l2][0-r2]滿足條件的數的個數 假設可以把某一個數拆分成[前面任意個數][00-0-11-1(個數相同)]的區間 那麼問題會簡單的多,因為任意一個a位的整數分別xo ...
- jQuery Validation Plugin
使用方式很简单,简单测试代码如下: <html> <head> <script type="text/javascript" src="./ ...
- Unity 自动生成组件索引类工具
Unity 自动生成组件索引类工具 需求由来 我们在写UI类时 需要获取预设中的组件 joystick = transform.Find("joystick"); backgrou ...
- Hadoop集群维护
HDFS小文件问题及解决方案:http://dongxicheng.org/mapreduce/hdfs-small-files-solution/ Hadoop升级方案(一):Hadoop 1.0内 ...
- Netty核心概念(7)之Java线程池
1.前言 本章本来要讲解Netty的线程模型的,但是由于其是基于Java线程池设计而封装的,所以我们先详细学习一下Java中的线程池的设计.之前也说过Netty5被放弃的原因之一就是forkjoin结 ...
- Aop学习笔记系列一
一.Aop解决了什么问题? 1.在说解决了什么问题之前,先介绍一些关键的知识点 a.功能需求:功能需求指项目中的增值需求,比如业务逻辑,UI,持久化(数据库). b.非功能需求:项目中次要的,但却不可 ...