• hdoj 1226 超级password 【隐图BFS】


    称号:hdoj 1226 超级password 


    分析:这题属于隐式图搜索,状态不是非常明显,须要自己建立。

    事实上搜索说白了就是暴力。

    这个题目就是,首先对给出的能够组成的全部的数依次枚举。长度从小到大。

    比方第一组例子,由于0不能出如今首位。那么我们枚举首位为1 和 7 看看漫步满足,

    满足的话枚举第二位10 11 17 以及 70 71 77 顺便保存他们取余 n 之后的值,这样就能够剪枝,搜索过的就不用反复搜索了。

    要求最早出现的BFS就可以,第一个搜到的就是。

    注意长度不大于500

    AC代码:

    #include <cstdio>
    #include <algorithm>
    #include <cstring>
    #include <string>
    #include <iostream>
    #include <vector>
    #include <cmath>
    #include <queue>
    using namespace std;
    const int inf = 0x3f3f3f3f;
    const int N = 15;
    int a[20];
    int flag[60000];
    struct Node
    {
        string s;
        int ss;
    };
    Node ans;
    int n,c,m;
    char solve(int x)
    {
        if(x>=0 && x<=9)
            return x+'0';
        return x-10+'A';
    }
    bool BFS()
    {
        memset(flag,0,sizeof(flag));
        queue<Node> q;
        Node now,next;
        for(int i=0;i<m;i++)
        {
            if(a[i]!=0)
            {
                now.s = solve(a[i]);
                now.ss = (a[i]%n);
                if(now.ss == 0)
                {
                    ans = now;
                    return true;
                }
                if(flag[now.ss]==0)
                {
                    flag[now.ss] = 1;
                    q.push(now);
                }
            }
        }
        while(!q.empty())
        {
            now = q.front();
            q.pop();
            //cout<<now.s<<" "<<now.ss<<endl;
            if(now.ss == 0)
            {
                ans = now;
                return true;
            }
            for(int i=0;i<m;i++)
            {
                next.s= now.s+solve(a[i]);
                next.ss = (now.ss*c+a[i])%n;
               // cout<<"NEXT:"<<next.s<<" "<<next.ss<<" "<<a[i]<<endl;
                if(flag[next.ss]==0)
                {
                    flag[next.ss] = 1;
                    q.push(next);
                }
            }
        }
        return false;
    }
    int main()
    {
        //freopen("Input.txt","r",stdin);
        int T;
        scanf("%d",&T);
        while(T--)
        {
            scanf("%d%d%d",&n,&c,&m);
            for(int i=0;i<m;i++)
            {
                char c[10];
                scanf("%s",c);
                if(c[0]>='A' && c[0]<='F')
                    a[i] = (c[0]-'A')+10;
                else
                    a[i] = c[0]-'0';
            }
            sort(a,a+m);
            if(n==0)
            {
                if(a[0]==0)
                    puts("0");
                else
                    puts("give me the bomb please");
                continue;
            }
            if(BFS() && ans.s.size()<=500)
                cout<<ans.s<<endl;
            else
                puts("give me the bomb please");
        }
        return 0;
    }
    


    版权声明:本文博客原创文章。博客,未经同意,不得转载。

  • 相关阅读:
    MySQL 对于千万级的大表要怎么优化?
    mysql数据库优化总结
    php 正则表达式怎么匹配标签里面的style?
    php一行代码获取本周一,本周日,上周一,上周日,本月一日,本月最后一日,上月一日,上月最后一日日期
    PHP过滤常用标签的正则表达式
    php冒泡排序
    PHP中__FUNCTION__与__METHOD__的区别
    关于PHP程序员技术职业生涯规划
    初识DSP
    MATLAB图像处理基础
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4630155.html
Copyright © 2020-2023  润新知