127. 单词接龙;131. 分割回文串

给定两个单词(beginWord 和 endWord)和一个字典,找到从 beginWord 到 endWord 的最短转换序列的长度。转换需遵循如下规则:


    每次转换只能改变一个字母。
    转换过程中的中间单词必须是字典中的单词。


说明:


    如果不存在这样的转换序列,返回 0。
    所有单词具有相同的长度。
    所有单词只由小写字母组成。
    字典中不存在重复的单词。
    你可以假设 beginWord 和 endWord 是非空的,且二者不相同。


示例 1:

输入:
beginWord = "hit",
endWord = "cog",
wordList = ["hot","dot","dog","lot","log","cog"]

输出: 5

解释: 一个最短转换序列是 "hit" -> "hot" -> "dot" -> "dog" -> "cog",
     返回它的长度 5。


示例 2:

输入:
beginWord = "hit"
endWord = "cog"
wordList = ["hot","dot","dog","lot","log"]

输出: 0

解释: endWord "cog" 不在字典中,所以无法进行转换。

class tire{
    bool isWord;
    unordered_mapnext;
public:
    tire():isWord(false){
        for(char i='a';i<='z';++i)
            next[i]=nullptr;
    }
    void insertWord(string s){
        tire *cur=this;
        for(int i=0;inext[s[i]])
                cur=cur->next[s[i]];            
            else{
                tire *temp=new tire();
                cur->next[s[i]]=temp;
                cur=temp;
            }
        cur->isWord=true;
    }
    bool hasWord(string s){
        tire *cur=this;
        for(int i=0;inext[s[i]])return false;
            cur=cur->next[s[i]];
        }
        return cur->isWord;
    }
    void findNeighber(string s,vector& vec){
        tire *cur=this;
        for(int i=0;inext[c]&&cur->next[c]->hasWord(s.substr(i+1))){
                    string temp=s;
                    temp[i]=c;
                    vec.push_back(temp);
                }
            }
            cur=cur->next[s[i]];
        }
    }
};
class Solution {
public:
    int ladderLength(string beginWord, string endWord, vector& wordList) {
        if(beginWord.size()==0||beginWord.size()!=endWord.size())return 0;
        int resCnt=1;
        tire *allWord=new tire(),*visited=new tire();
        allWord->insertWord(beginWord);
        for(int i=0;iinsertWord(wordList[i]);
        if(!allWord->hasWord(endWord))return 0;
        queueq;
        q.push(beginWord);
        while(q.size()){
            int qSize=q.size();
            ++resCnt;
            while(qSize--){
                string temp=q.front();
                q.pop();
                vectorvec;                
                allWord->findNeighber(temp,vec);
                for(int i=0;ihasWord(vec[i]))continue;
                    if(vec[i]==endWord)return resCnt;
                    q.push(vec[i]);
                    visited->insertWord(vec[i]);                    
                }
            }
        }
        return 0;
    }
};

给定一个字符串 s,将 s 分割成一些子串,使每个子串都是回文串。

返回 s 所有可能的分割方案。

示例:

输入: "aab"
输出:
[
  ["aa","b"],
  ["a","a","b"]
]

class Solution {
    vector> res;
    vectorpath;
    string sel;
public:
    vector> partition(string s) {
        if(s.size()<1)return {};
        sel=s;
        backTrack(0);
        return res;
    }
    bool isOrNot(int start,int end){
        while(start

 

你可能感兴趣的:(LeetCode)