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

密码锁

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;
	
	
	}

}

全部评论
武忠祥老师,您的代码写的也太好了
点赞 回复 分享
发布于 2023-02-07 14:00 江苏

相关推荐

无敌虾孝子:喜欢爸爸还是喜欢妈妈
点赞 评论 收藏
分享
10-25 12:05
已编辑
湖南科技大学 Java
若梦难了:我有你这简历,已经大厂乱杀了
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务