玛雅人的密码

玛雅人的密码

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

没有任何优化的无脑暴力bfs

#include<iostream>
#include<queue>
#include<string>
using namespace std;
struct mitery{
    int index;
    string s;
    mitery(int i,string ss):index(i),s(ss){}
};
void bfs(string s){
    queue<mitery> q;
    q.push(mitery(0,s));
    while(!q.empty()){
        mitery t=q.front();
        q.pop();
        string ts=t.s;
        if(ts.find("2012")!=string::npos){
            cout<<t.index<<endl;return ;
        }
        for(int i=0;i<ts.size()-1;i++){
            swap(ts[i],ts[i+1]);
            q.push(mitery(t.index+1,ts));
            swap(ts[i],ts[i+1]);
        }
    }
    cout<<-1<<endl;
} 
int main(){
    int n;
    string s;
    while(cin>>n>>s){
        bfs(s);
    }
    return 0;
}
全部评论
没有2012,就吃了炫迈
4 回复 分享
发布于 2022-03-18 11:08
为什么bfs循环没有终止条件不会一直运行下去?
3 回复 分享
发布于 2022-03-03 10:55
没有2012,直接g
1 回复 分享
发布于 2022-04-25 14:56
为什么要swap两次阿?
1 回复 分享
发布于 2022-03-26 17:40

相关推荐

2025-12-14 11:43
黑龙江大学 Java
用微笑面对困难:确实比较烂,可以这么修改:加上大学的qs排名,然后大学简介要写一些,然后硕士大学加大加粗,科研经历第一句话都写上在复旦大学时,主要负责xxxx,简历左上角把学校logo写上,建议用复旦大学的简历模板
点赞 评论 收藏
分享
评论
19
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务