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

密码锁

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

}

全部评论

相关推荐

06-15 02:05
已编辑
南昌航空大学 数据分析师
Eason三木:你如果想干技术岗,那几个发公众号合唱比赛的经历就去掉,优秀团员去掉,求职没用。然后CET4这种不是奖项,是技能,放到下面的专业技能里或者单独列一个英语能力。 另外好好改改你的排版,首行缩进完全没有必要,行间距好好调调,别让字和标题背景黏在一起,你下面说能做高质量PPT你得展现出来啊,你这简历排版我用PPT做的都能比你做的好。 然后自我评价,你如果要干数据工程师,抗压能力强最起码得有吧。
点赞 评论 收藏
分享
fRank1e:吓得我不敢去外包了,但是目前也只有外包这一个实习,我还要继续去吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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