zoukankan      html  css  js  c++  java
  • 超级密码(bfs)

    超级密码

    Time Limit : 20000/10000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)
    Total Submission(s) : 4   Accepted Submission(s) : 0
    Problem Description
    Ignatius花了一个星期的时间终于找到了传说中的宝藏,宝藏被放在一个房间里,房间的门用密码锁起来了,在门旁边的墙上有一些关于密码的提示信息:
    密码是一个C进制的数,并且只能由给定的M个数字构成,同时密码是一个给定十进制整数N(0<=N<=5000)的正整数倍(如果存在多个满足条件的数,那么最小的那个就是密码),如果这样的密码存在,那么当你输入它以后门将打开,如果不存在这样的密码......那就把门炸了吧.

    注意:由于宝藏的历史久远,当时的系统最多只能保存500位密码.因此如果得到的密码长度大于500也不能用来开启房门,这种情况也被认为密码不存在.
     
    Input
    输入数据的第一行是一个整数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.我保证输入数据都是合法的.
     
    Output
    对于每组测试数据,如果存在要求的密码,则输出该密码,如果密码不存在,则输出"give me the bomb please". 注意:构成密码的数字不一定全部都要用上;密码有可能非常长,不要试图用一个整型变量来保存密码;我保证密码最高位不为0(除非密码本身就是0).
     
    Sample Input
    3 22 10 3 7 0 1 2 10 1 1 25 16 3 A B C
     
    Sample Output
    110 give me the bomb please CCB [hint]Hint[/hint] Huge input, scanf is recommended.
    ac代码:
     1 #include<stdio.h>
     2 #include<string.h>
     3 #include<queue>
     4 #include<algorithm>
     5 using namespace std;
     6 const int MAXN=550;
     7 int num[20];
     8 struct Node{
     9     int s[MAXN];
    10     int len;
    11 };
    12 int M,C,N;
    13 int vis[5050];
    14 int mod(Node a){
    15     int x=0;
    16     for(int i=0;i<a.len;i++){
    17         x=(x*C+a.s[i])%N;
    18     }
    19     return x;
    20 }
    21 void print_ans(Node a){
    22     for(int i=0;i<a.len;i++){
    23         if(a.s[i]>=0&&a.s[i]<=9)printf("%c",a.s[i]+'0');
    24         else printf("%c",a.s[i]-10+'A');
    25     }
    26     puts("");
    27 }
    28 void bfs(){
    29     memset(vis,0,sizeof(vis));
    30     queue<Node>dl;
    31     Node a;
    32     a.len=1;
    33     int md;
    34     for(int i=0;i<M;i++){
    35         a.s[0]=num[i];
    36         md=mod(a);
    37         //printf("%d ",md);
    38         if(vis[md]||num[i]==0)continue;
    39         if(md==0&&num[i]){
    40             printf("%d
    ",num[i]);
    41             return;
    42         }
    43     //    printf("%d ",md);
    44         vis[md]=1;
    45         dl.push(a);
    46     }
    47     while(!dl.empty()){
    48         a=dl.front();
    49         dl.pop();
    50     for(int i=0;i<M;i++){
    51         if(a.len==1&&a.s[0]==0)continue;
    52         a.s[a.len]=num[i];
    53         a.len++;
    54         //puts("**");
    55         md=mod(a);
    56     //    printf("%d ",md);
    57     if(vis[md]||a.len>500){
    58         a.len--;//这里少了这个错的啊。。。。。无奈。。。。。 
    59         continue;
    60     }
    61     //    print_ans(a);
    62         if(md==0){
    63             
    64             print_ans(a);
    65             return;
    66         }
    67         vis[md]=1;
    68         dl.push(a);
    69         a.len--;
    70         }
    71     }
    72     puts("give me the bomb please");
    73 }
    74 int main(){
    75     int T;
    76     scanf("%d",&T);
    77     char s[5];
    78     while(T--){
    79     scanf("%d%d%d",&N,&C,&M);
    80         for(int i=0;i<M;i++){
    81             scanf("%s",s);
    82             if(s[0]>='0'&&s[0]<='9')num[i]=s[0]-'0';
    83             else num[i]=s[0]-'A'+10;
    84         //    printf("%d ",num[i]);
    85         }
    86         sort(num,num+M);
    87         if(N)bfs();
    88         else if(!num[0])puts("0");
    89         else puts("give me the bomb please");
    90     }
    91     return 0;
    92 }
     wa代码,求改正。。。。
    感觉没错啊;
    代码:
     1 #include<stdio.h>
     2 #include<string>
     3 #include<queue>
     4 #include<string.h>
     5 #include<algorithm>
     6 #define mem(a) memset(a,0,sizeof(a))
     7 using namespace std;
     8 const int MAXN=1e4+10;
     9 int cmp(char a,char b){
    10     /*if(a<b)return 1;
    11     else return 0;*/
    12     return a<b;
    13 }
    14 int vis[MAXN],pre[MAXN];
    15 char num[20];
    16 int nu[20];
    17 char al[MAXN];
    18 int n,m,C;
    19 void print_ans(){
    20     int r=0;
    21     string ans;
    22     while(ans.empty()||r!=0){
    23         ans+=al[r];
    24         r=pre[r];
    25     }
    26     reverse(ans.begin(),ans.end());
    27     puts(ans.c_str()); 
    28 }
    29 void bfs(){
    30     queue<int>dl;
    31     dl.push(0);
    32     while(!dl.empty()){
    33         int f1,f2;
    34         f1=dl.front();//**
    35         dl.pop();
    36         for(int i=0;i<m;i++){
    37             if(nu[i]==0&&f1==0)continue;
    38         f2=(f1*C+nu[i])%n;
    39         if(vis[f2])continue;
    40         pre[f2]=f1;
    41         al[f2]=num[i];
    42         if(f2==0){
    43             //printf("%d %d
    ",f1,f1*C+nu[i]);
    44             print_ans();
    45             return;
    46             }
    47             vis[f2]=1;
    48         dl.push(f2);
    49         }
    50     }
    51     puts("give me the bomb please");
    52 }
    53 int main(){
    54     int T;
    55     scanf("%d",&T);
    56     while(T--){
    57         mem(vis);mem(pre);mem(al);
    58         char x[5]; 
    59         scanf("%d%d%d",&n,&C,&m);
    60         for(int i=0;i<m;i++){
    61             scanf("%s",x);
    62             num[i]=x[0];
    63             //printf("%c ",num[i]);
    64         }
    65         sort(num,num+m);
    66         int o=0;
    67         for(int i=0;i<m;i++){
    68             if(num[i]>='A'&&num[i]<='Z')nu[i]=10+num[i]-'A';
    69             else nu[i]=num[i]-'0';
    70             if(num[i]=='0')o=1;
    71             //printf("%c %d ",num[i],nu[i]);
    72         }
    73         if(n!=0)bfs();
    74         else if(o)puts("0");
    75         else puts("give me the bomb please");
    76     }
    77     return 0;
    78 }
  • 相关阅读:
    (八十五)c#Winform自定义控件-引用区块-HZHControls
    (八十四)c#Winform自定义控件-导航菜单(Ribbon菜单)-HZHControls
    (八十三)c#Winform自定义控件-导航菜单(扩展)-HZHControls
    (八十二)c#Winform自定义控件-穿梭框-HZHControls
    (八十一)c#Winform自定义控件-时间轴-HZHControls
    (八十)c#Winform自定义控件-分割线标签-HZHControls
    (七十九)c#Winform自定义控件-导航菜单-HZHControls
    (七十八)c#Winform自定义控件-倒影组件-HZHControls
    (七十七)c#Winform自定义控件-采样控件-HZHControls
    (七十六)c#Winform自定义控件-表单验证组件-HZHControls
  • 原文地址:https://www.cnblogs.com/handsomecui/p/4865554.html
Copyright © 2011-2022 走看看