青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

FireEmissary

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

經典的求公共子序列算法需要兩個序列的長度已知.而且通常用于計算字符串的公共子序列.

我實現的算法針對原有的算法輸入需求解耦合,使得算法極度可適配.能用于字符串公共子序列計算和文件diff計算.理論上能用于任何具備相似特征的兩個序列的公共子序列計算.

LCS_Calculate有三個變種:

 

template<typename L_Iterator,typename R_Iterator,typename Container>

LCS_Size FEtool::LCS_Calculate(L_Iterator lbeg,L_Iterator lend,  R_Iterator rbeg,R_Iterator rend,Container 
&out);

template
<typename L_Iterator,typename R_Container,typename Container>

inline LCS_Size FEtool::LCS_Calculate(L_Iterator lbeg,L_Iterator lend,  R_Container 
const&rcontainer, Container &out);

template
<typename L_Container,typename R_Container,typename Container>

inline LCS_Size FEtool::LCS_Calculate(L_Container 
const& lcontainer,   R_Container const&rcontainer, Container &out);

L_Iterator接受輸入迭代器. R_Iterator接受隨機迭代器. L_ContainerR_Container分別調用它們的begin()end()方法轉調用到LCS_Calculate的第一個版本.

L_*打頭的指代比較序列中左邊那個,R_*打頭的指代比較序列中右邊那個.

最后一個參數Container&out接收一個容器用來輸出序列各段相同的地方.典型的Container參數為std::deque<FEtool::SectionCommon> section;也可以為FEtool:: EmptyContainer.

class EmptyContainer
{
public:
    
void push_back(SectionCommon const&){};
    LCS_Size size()
{return 0;}
    
void clear(){}
}
;


如果為FEtool:: EmptyContainer參數則通過模板特化代碼選擇不計算兩段序列的相同部分。

 

struct LCS_Compare_Trait
{
template
<typename L,typename R>
static   bool equal(L const& left, R const& right)
        
{
            
return left==right;
        }

}
;

定義了比較算法,默認用operator==.你可以在FEtool空間通過特化或偏特化LCS_Compare_Trait:: equal來定制它.

 

struct SectionCommon
{
    LCS_Size L_begin;
    LCS_Size R_begin;
    LCS_Size count;
    
void clear(){L_begin=0;R_begin=0;count=0;}
}
;

指示兩個序列的相同部分. 比如SectionCommon:: L_begin0, SectionCommon:: R_begin10, SectionCommon::count5.就表示左邊序列從0開始的5個數據,和右邊序列從10開始的5個數據都相同.

 

LCS_Calculate內部根據傳入參數優化實現.經過對經典的動態規劃解公共子序列算法的考察發現,外圍那個循環只需要遍歷它代表的序列一次;即左邊序列則滿足輸入迭代器即可.它要求右邊序列始終是傳入隨機迭代器.內部計算用到的數組使用了滾動數組(LCSArray)實現,空間占用為右邊序列長度*2.


LCS_Calculate
的最后一個參數不為EmptyContainer則會計算公共子序列在左右序列中各段的順序和長度.這里L_Iterator是不是隨機訪問迭代器就會影響到性能了.L_Iterator不是隨機迭代器內部就會用到一個動態增長的輔助數組(TrackArrayDynamic)來做回溯; L_Iterator是隨機迭代器則直接一次申請(左序列*右序列)這么大的空間(TrackArrayStatic)來輔助回溯計算.
而如果LCS_Calculate的最后一個參數為EmptyContainer則會選擇一個空數組(TrackArrayEmpty)實現.TrackArrayEmpty類把所有操作展開為空操作.

所有這些,基于模板來自動選擇.用戶不需要指定不同的函數來優化性能:

template<typename L_Iterator,typename R_Iterator,typename Container/*vector<LCS_Section>*/>
LCS_Size LCS_Calculate(L_Iterator lbeg,L_Iterator lend,
                    R_Iterator rbeg,R_Iterator rend,
                    Container 
&out)
{
    
out.clear();
    detail::LCSArray array(rend
-rbeg);
   typedef detail::SelectTrackArray
<Container,typename std::iterator_traits<L_Iterator>::iterator_category> SelectTrack;//選擇適當的回溯數組
   typename SelectTrack::Array trackArr(SelectTrack::TotalRows(lbeg,lend),array.columns());//選擇適當的回溯數組
    LCS_Size leftSize;
    LCS_Size rightSize;
  
for( leftSize=1;lbeg!=lend;++lbeg,++leftSize)//外層只需要是輸入迭代器就可
        
for( rightSize=1;rightSize<=array.columns();++rightSize)
        
{
            
if(LCS_Compare_Trait::equal(*lbeg,*(rbeg+rightSize-1))){
                array(leftSize,rightSize)
=array(leftSize-1,rightSize-1)+1;
                trackArr(leftSize,rightSize)
=0;
            }

            
else if(array(leftSize-1,rightSize)>=array(leftSize,rightSize-1)){
                array(leftSize,rightSize)
=array(leftSize-1,rightSize);
                trackArr(leftSize,rightSize)
=1;
            }

            
else{
                array(leftSize,rightSize)
=array(leftSize,rightSize-1);
                trackArr(leftSize,rightSize)
=-1;
            }


        }

        detail::LCS_KeepTrack(trackArr,
out);

    
return array(leftSize-1,array.columns());

}


完整代碼包括測試代碼下載

posted on 2010-03-27 19:31 FireEmissary 閱讀(2849) 評論(1)  編輯 收藏 引用

評論

# re: 最長公共子序列的泛型算法 2010-03-28 10:22 expter
我覺得用c語言直接寫DP還清晰明了點。。。  回復  更多評論
  


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            91久久精品久久国产性色也91| 午夜激情综合网| 国产精品久久久久久久久久免费 | 久久成人精品电影| 一区二区三区四区国产精品| 亚洲第一网站| 夜夜嗨av一区二区三区网站四季av| 亚洲国产成人精品视频| 91久久久在线| 亚洲视频综合在线| 亚洲专区一区二区三区| 香蕉久久夜色精品| 欧美成人一品| 一区二区冒白浆视频| 亚洲素人在线| 美女91精品| 国产伦精品一区二区| 亚洲国产一区在线| 亚洲一区黄色| 欧美成人精品影院| 亚洲欧美日韩一区在线| 欧美精品在线一区二区三区| 国产日韩一区二区三区在线播放 | 在线观看日韩欧美| 亚洲无限av看| 亚洲欧洲精品一区| 亚洲欧美国产高清| 欧美日本不卡| 亚洲三级观看| 亚洲人成在线影院| 麻豆国产va免费精品高清在线| 亚洲国产精品小视频| 久久中文久久字幕| 国语自产在线不卡| 久久久久久网| 噜噜噜在线观看免费视频日韩| 伊人精品视频| 牛牛影视久久网| 米奇777超碰欧美日韩亚洲| 亚洲电影第1页| 亚洲电影在线看| 欧美精品观看| 午夜精彩国产免费不卡不顿大片| 日韩亚洲欧美一区二区三区| 国产精品国产馆在线真实露脸 | 亚洲精品在线免费| 亚洲精品免费一区二区三区| 欧美日韩国产免费观看| 亚洲午夜一区二区| 亚洲欧美综合一区| 在线观看视频免费一区二区三区| 欧美激情一区二区三区蜜桃视频 | 久久精品最新地址| 亚洲欧洲一区二区三区| 亚洲婷婷国产精品电影人久久| 欧美日韩在线免费视频| 久久久久高清| 欧美日韩在线第一页| 久久精品一区蜜桃臀影院| 欧美日韩小视频| 免费久久99精品国产自在现线| 欧美午夜美女看片| 亚洲精品久久久一区二区三区| 亚洲视频播放| 99精品视频免费在线观看| 久久久国产一区二区| 午夜国产不卡在线观看视频| 欧美日韩国产丝袜另类| 美玉足脚交一区二区三区图片| 国产欧美一区二区在线观看| 一片黄亚洲嫩模| 亚洲深夜福利视频| 欧美日韩大片| 一本久久综合亚洲鲁鲁| 亚洲欧美国产精品桃花| 国产精品亚洲综合天堂夜夜| 99re这里只有精品6| 99在线热播精品免费| 欧美日韩精品中文字幕| 99国产精品国产精品久久| 亚洲淫性视频| 海角社区69精品视频| 欧美电影在线| 亚洲一区免费| 欧美国产专区| 亚洲男人的天堂在线| 激情欧美日韩一区| 免费欧美视频| 亚洲字幕在线观看| 女同一区二区| 羞羞漫画18久久大片| 亚洲国产一区二区视频| 国产精品亚洲一区| 欧美成人黄色小视频| 亚洲欧美经典视频| 亚洲黄网站在线观看| 欧美一区二区国产| 99精品久久久| 尤物精品在线| 国产一区999| 国产精品久久久久久久久久久久久久 | 亚洲午夜在线观看| 国产视频久久网| 欧美日本高清视频| 久久综合伊人77777| 午夜精品福利一区二区蜜股av| 美女精品一区| 蜜桃伊人久久| 欧美a级理论片| 玖玖国产精品视频| 久久国产精品久久精品国产| 亚洲一区二区在线看| 一本大道久久a久久综合婷婷 | 国产精品一区2区| 欧美日韩一二区| 欧美三级电影一区| 欧美新色视频| 国产麻豆综合| 国产一级揄自揄精品视频| 国语自产偷拍精品视频偷 | 亚洲综合二区| 午夜日韩视频| 免费在线看一区| 欧美日韩不卡合集视频| 国产精品美女在线观看| 国内精品久久久| 亚洲日本va午夜在线电影| 99综合在线| 欧美中文字幕久久| 国产偷自视频区视频一区二区| 国产在线欧美日韩| 亚洲精品日本| 欧美在线一二三| 亚洲美女免费精品视频在线观看| 亚洲一区制服诱惑| 久久久久久久久久久久久9999| 欧美日韩一区在线播放| 国产视频一区二区在线观看| 亚洲三级性片| 久久精品国产999大香线蕉| 亚洲国产精品高清久久久| 亚洲欧美色婷婷| 欧美日韩中文字幕在线视频| 亚洲国内高清视频| 久久一区二区三区国产精品| 亚洲一区二区免费在线| 欧美日韩一区二区视频在线观看 | 99精品国产在热久久下载| 久热精品在线| 看片网站欧美日韩| 亚洲国产成人精品久久| 美女免费视频一区| 久热精品视频在线免费观看| 精品91在线| 欧美福利视频| 欧美高清视频在线| 亚洲国产综合在线| 亚洲国产导航| 欧美日韩一区高清| 性欧美大战久久久久久久免费观看| 在线视频精品一区| 国产三区精品| 美女黄毛**国产精品啪啪| 欧美精品电影| 亚洲欧美视频在线观看视频| 久久国产精品久久w女人spa| 亚洲高清激情| 亚洲制服av| 亚洲精品国产精品乱码不99按摩| 亚洲精品乱码久久久久久按摩观| 一区二区国产在线观看| 夜夜精品视频| 亚洲高清不卡一区| 亚洲桃花岛网站| 亚洲三级电影全部在线观看高清| 亚洲精品美女在线观看播放| 国产综合色产| 99www免费人成精品| 亚洲国产欧美不卡在线观看| 亚洲视频在线看| 一区二区三区久久| 另类春色校园亚洲| 欧美专区一区二区三区| 欧美日韩国产综合视频在线观看中文 | 午夜欧美精品| 欧美视频免费在线观看| 亚洲国产高清aⅴ视频| 黄色成人小视频| 欧美在线视频导航| 午夜在线精品| 国产精品视频久久一区| 一本色道久久综合狠狠躁的推荐| 亚洲毛片播放| 欧美日韩精品免费在线观看视频| 亚洲黄网站黄| 一本色道久久综合亚洲精品高清| 欧美国产专区| 欧美激情1区| 一级日韩一区在线观看| 欧美日韩亚洲三区|