题解 | #玛雅人的密码#

玛雅人的密码

http://www.nowcoder.com/practice/761fc1e2f03742c2aa929c19ba96dbb0

#include <iostream>
#include <string>
#include <vector>
#include <queue>
#include <set>
using namespace std;

set<string> st;

void BFS(int n, string s) {
    queue<string> que;
    que.push(s);          //压入初始状态
    st.insert(s);
    int cnt = 0;
    while (!que.empty()) {
        int size = que.size();
        for (int i = 0; i < size; i++) {
            string tmp = que.front();
            que.pop();
            if (tmp.find("2012") != string::npos) {
                cout << cnt << endl;
                return;
            }
            for (int j = 0; j < n - 1; j++) {
                string tmp1 = tmp;
                char c = tmp1[j];
                tmp1[j] = tmp1[j+1];
                tmp1[j+1] = c;
                if (st.find(tmp1) == st.end()) {
                    que.push(tmp1);
                }
            }
        }
        cnt++;
    }
    if (cnt == 0) cout << "-1" << endl;
}

int main() 
{
    int N;
    while (cin >> N) {
        string s;
        cin >> s;
        BFS(N, s);
    }
    return 0;
}
全部评论

相关推荐

牛舌:如果我不想去,不管对方给了多少,我一般都会说你们给得太低了。这样他们就会给下一个offer的人更高的薪资了。
点赞 评论 收藏
分享
10-25 00:32
香梨想要offer:感觉考研以后好好学 后面能乱杀,目前这简历有点难
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务