LC-词语序列

词语序列

//词语序列
/*给定两个单词(初始单词和目标单词)和一个单词字典,请找出所有的从初始单词到目标单词的最短转换序列的长度: 
每一次转换只能改变一个单词 
每一个中间词都必须存在单词字典当中 
例如: 
给定的初始单词start="hit", 
目标单词end ="cog"。 
单词字典dict =["hot","dot","dog","lot","log"] 
一个最短的转换序列为"hit" -> "hot" -> "dot" -> "dog" -> "cog", 
返回长度5*/
#include<unordered_set>
#include<algorithm>
#include<iostream>
#include<string>
#include<queue>
using namespace std;

class Solution {
public:
	//bfs层序遍历
	//利用队列每次将当前待寻找的string放入队列中,找到一个转换string即放入队列,
	//并将字典中的该项删除
	int res = 1;
	queue<string> strQueue;
	bool isTransWord(string s, string d)
	{
		if (s.size() != d.size())
			return false;
		int count = 0;
		for (int i = 0; i < s.size(); i++)
		{
			if (s[i] != d[i])
				count++;
		}
		return count == 1 ? true : false;
	}

	int ladderLength(string start, string end, unordered_set<string> &dict) {
		
		strQueue.push(start);
		while (!strQueue.empty())
		{
			int queuesize = strQueue.size();
			while (queuesize > 0)
			{
				string str = strQueue.front();
				strQueue.pop();
				queuesize--;
				if (isTransWord(str, end))
				{
					return res;
				}
				
				for (auto it = dict.begin(); it != dict.end(); it++)
				{
					if (isTransWord(*it, str))
					{
						strQueue.push(*it);
						dict.erase(*it);
						it = dict.begin();    //删除元素后需要重新分配迭代器
					}
				}
				
			}
			
			res++;
		}
		return 0;
	}
};


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值