• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            FireEmissary

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              14 隨筆 :: 0 文章 :: 20 評論 :: 0 Trackbacks

            Given a 2D board and a list of words from the dictionary, find all words in the board.

            Each word must be constructed from letters of sequentially adjacent cell, where "adjacent" cells are those horizontally or vertically neighboring. The same letter cell may not be used more than once in a word.

            For example,
            Given words = ["oath","pea","eat","rain"] and board =

            [   ['o','a','a','n'],   ['e','t','a','e'],   ['i','h','k','r'],   ['i','f','l','v'] ] 
            Return ["eat","oath"].

            Note:
            You may assume that all inputs are consist of lowercase letters a-z.


            做完Word Search點下面的鏈接跳到212...大量要查找的單詞,提示用trie樹.網(wǎng)上果然都是用trie樹的....不過只需要用到信息能剪枝就好啦就沒建立一個真正的trie樹.
             struct Layer{
                     
            int close=0;//>0代表一個完整的詞且代表在words里的索引+1
                    array<Layer*,26>  next{};//26個字母,不為0即代表當(dāng)前找到的是前綴或完整詞
                    ~Layer(){
                        
            for(Layer*l:next)
                          delete l;
                    }
                };
                
            void find(vector<vector<char>>& board,int i,int j ,vector<string>& words,Layer*lay,vector<string>&res)
                {        
                      
            char cur=board[i][j];
                      
            if(cur=='-')return;
                      lay
            =lay->next[cur-'a'];
                      
            if(!lay)return;
                       
            if(lay->close){
                          res.push_back(words[lay
            ->close-1]);
                          lay
            ->close=0;
                      }
                      board[i][j]
            ='-';//依然寫入其它字符防止重復(fù)使用
                         if(i+1<board.size())find(board,i+1,j,words,lay,res);
                         
            if(i>0)find(board,i-1,j,words,lay,res);
                         
            if(j+1<board[0].size())find(board,i,j+1,words,lay,res);
                         
            if(j>0)find(board,i,j-1,words,lay,res);
                      board[i][j]
            =cur;
                }
                vector
            <string> findWords(vector<vector<char>>& board, vector<string>& words) {
                      Layer root;
                      
            for(int i=0;i<words.size();++i)
                       {
                           Layer
            *cur=&root;
                           
            for(char c:words[i]){
                               
            if(!cur->next[c-'a']){
                                cur
            ->next[c-'a']=new Layer;
                               }
                               cur
            =cur->next[c-'a'];
                           }
                           cur
            ->close=i+1;
                       }
                      vector
            <string> res;
                      
            for(int i=0;i<board.size();++i)
                        
            for(int j=0;j<board[0].size();++j)
                        {
                            find(board,i,j,words,
            &root,res);
                        }
                        
            return res;
                }
            posted on 2016-03-27 20:57 FireEmissary 閱讀(1203) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            国产成人精品综合久久久久| 大蕉久久伊人中文字幕| 热99RE久久精品这里都是精品免费| 国产成人精品久久一区二区三区av | 久久久久国产一级毛片高清板| 激情久久久久久久久久| 久久成人小视频| 国产亚洲色婷婷久久99精品| 国产精品熟女福利久久AV | 久久久久久精品成人免费图片| 久久久久久久精品妇女99 | 97视频久久久| 99久久综合狠狠综合久久| 狠狠精品久久久无码中文字幕| 国产精品美女久久久| 久久丫忘忧草产品| 国内精品久久久久久久久电影网 | 久久93精品国产91久久综合| 少妇内射兰兰久久| 伊人久久大香线蕉精品| 亚洲va国产va天堂va久久| 亚洲精品NV久久久久久久久久| 国产一区二区三区久久精品| 久久精品国产亚洲av麻豆蜜芽 | 久久国产成人午夜aⅴ影院| 精品久久久久久中文字幕大豆网| 久久中文娱乐网| 国产精品久久毛片完整版| 国产成人精品综合久久久| 亚洲人成无码网站久久99热国产 | 亚洲精品无码久久久久AV麻豆| 久久96国产精品久久久| 久久久久久无码Av成人影院| 区久久AAA片69亚洲| 久久精品国产男包| 亚洲国产成人乱码精品女人久久久不卡| 国产精品一久久香蕉国产线看观看| 久久久一本精品99久久精品88| 亚洲色大成网站WWW久久九九| 久久国产欧美日韩精品| 久久人人爽人人爽人人片AV不|