题解 | #密码锁#(深度必超时 玛雅人不超时因为字符串短)

密码锁

https://www.nowcoder.com/practice/7da5fb77ba2e462c909fbff8f61584be

#include<iostream>
#include<vector>
#include<string>
#include<algorithm>
#include<queue>
#include<map>
using namespace std;
struct ele                //记录层数
{
	string str;
	int step;
};
int BFS(string s)                  //广度搜索
{
	map<string, int> visited;        //访问标记数组
	queue<ele> con;            //保存数据队列
	ele k;
	k.str = s;
	k.step = 0;
	con.push(k);
	visited[s] = 1;
	int step = -1;

	while (!con.empty())
	{
		
	    ele z = con.front();
        con.pop();
		if (z.str.find("2012") != string::npos)
		{
			step = z.step;
			break;
		}
		else
		{
			z.step++;
			for (int i = 0; i < z.str.size() - 1; i++)
			{
				swap(z.str[i], z.str[i + 1]);
				if (visited.find(z.str) == visited.end())
				{
					con.push(z);
					visited[z.str] = 1;
				}
				swap(z.str[i], z.str[i + 1]);
			}
		}
	}
	return step;

}
int main()
{
	int n;
	while (cin >> n)
	{
		string s;
		cin >> s;
		cout << BFS(s) << endl;
	
	
	}

}

全部评论

相关推荐

12-15 12:50
河北工程大学
sta666:我也是这个国际商业化的,三天,一天一面,就通过了,不过我是后端实习生,好好面感觉能过。
点赞 评论 收藏
分享
求个付费实习岗位:这种就是吃满时代红利又没啥技术水平,只能靠压力学生彰显优越感的老登,别太在意了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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