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

上次說,LCS有O(n^2 / logn)的解法。這個解法是在字符集不大的情況下,先預處理,再用位運算做狀態轉移。
唐文斌曾經翻譯過一篇論文,專門討論這個問題。

應richardxx的要求,我把那篇論文貼在這里:
基于位運算的最長公共子序列算法

下面是練習題(n = 10000 的LCS)
http://acm.whu.edu.cn/oak/problem/problem.jsp?problem_id=1210

和我的解答

#include <stdio.h> 
#include 
<string.h> 

#define    WLEN      32 
#define    LOGWLEN      5 
#define    SMAX      16384 
#define    BITMAX      512 
#define    ALPHASIZE 128 

typedef unsigned 
int WORD; 
typedef 
char INDEX; 

int nwords; 
WORD bit1[BITMAX]; 
WORD bit2[BITMAX]; 
WORD a_strings[ALPHASIZE][BITMAX]; 
WORD 
*pb1,*pb2,*t1; 

WORD bitmask[LOGWLEN]
={0x55555555,0x33333333,0x0f0f0f0f,0x00ff00ff,0x0000ffff}

void alphastrings(INDEX *s,int len) 
    register INDEX 
*p; 
    register 
int i,j; 

    
for (i=0;i<ALPHASIZE;i++for (j=0;j<nwords;j++) a_strings[i][j]=0
    p
=s; 
    j
=len; 
    
for (i=0;i<j;i++) a_strings[*(p++)][i/WLEN]|=1<<(i%WLEN); 
     
    
return
}
 

void bitops(WORD *last,WORD *cur,INDEX index) 
    register WORD x,y; 
    register 
int j; 
    register WORD 
*a_s; 
    register WORD top_borrow,bottombit; 

    a_s
=&a_strings[index][0]; 
    bottombit
=1
    
for (j=0;j<nwords;j++
        y
=*(last++); 
        x
=y|*(a_s++); 
        top_borrow
=(y>>(WLEN-1))&0x1
        y
=((y<<1)|bottombit); 
        
if (x<y) top_borrow=1
        
*(cur++)=x&((x-y)^x); 
        bottombit
=top_borrow; 
    }
 
     
    
return
}
 

int bitcount(WORD *wp) 
    register WORD w,count; 
    register 
int j,rshift,i; 

    count
=0
    
for (i=0;i<nwords;i++
        w
=*(wp++); 
        rshift
=1
        
for (j=0;j<LOGWLEN;j++
            w
=(w&bitmask[j])+((w&~bitmask[j])>>rshift); 
            rshift
<<=1
        }
 
        count
+=w; 
    }
 
     
    
return count; 
}
 

int bitlcs(INDEX *a,int lena,INDEX *b,int lenb) 
    register 
int i; 
    register INDEX 
*pbstring; 
    register 
int j,k; 

    nwords
=(lena+WLEN-1)/WLEN; 
    alphastrings(a,lena); 
    pb1
=&bit1[0]; 
    
for (i=0;i<nwords;i++*pb1++=0
    pb1
=&bit1[0]; 
    pb2
=&bit2[0]; 
    pbstring
=b; 
    
for (i=1;i<=lenb;i++
        bitops(pb1,pb2,
*(pbstring++)); 
        t1
=pb1; pb1=pb2; pb2=t1; 
    }
 
     
    
return bitcount(pb1); 
}
 

int main() 
    
char sa[SMAX],sb[SMAX]; 
    
while (scanf("%s%s",sa,sb)!=EOF) printf("%d\n",bitlcs(sa,strlen(sa),sb,strlen(sb))); 
    
return 0
}
 
posted on 2007-10-19 16:56 Felicia 閱讀(1389) 評論(5)  編輯 收藏 引用 所屬分類: 動態規劃
Comments
  • # re: [動態規劃]O(n^2 / logn)的LCS
    richardxx
    Posted @ 2007-12-30 03:37
    想請問下唐的論文的題目是?
    望告知。。
      回復  更多評論   
  • # re: [動態規劃]O(n^2 / logn)的LCS
    Felicia
    Posted @ 2007-12-30 10:49
    我已經修改了文章,把那個論文上傳了。  回復  更多評論   
  • # re: [動態規劃]O(n^2 / logn)的LCS
    richardxx
    Posted @ 2007-12-31 13:38
    很感謝felicia! :> :P  回復  更多評論   
  • # re: [動態規劃]O(n^2 / logn)的LCS
    ecnu_zp
    Posted @ 2008-07-15 10:55
    太牛了.  回復  更多評論   
  • # re: [動態規劃]O(n^2 / logn)的LCS
    NH2T
    Posted @ 2009-07-03 16:54
    thank u very much
    i love you  回復  更多評論   
 
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            狠狠色丁香婷婷综合| 久久精品国产视频| 久久一区中文字幕| 久久久久久久精| 久久婷婷久久一区二区三区| 久久天堂成人| 亚洲电影欧美电影有声小说| 免费成人av在线看| 欧美激情麻豆| 亚洲激情一区| 亚洲一级片在线看| 亚洲一区二区在线免费观看视频| 亚洲一区欧美| 久久久久久久久一区二区| 欧美一区二区三区免费观看视频| 久久青草久久| 欧美**字幕| 欧美精品在线观看91| 欧美另类高清视频在线| 欧美精品一区二区精品网| 欧美精品aa| 欧美日韩一区高清| 国产精品一区二区你懂得 | 久热精品视频| 欧美刺激性大交免费视频| 欧美韩日一区| 欧美日韩天天操| 国产精品久久久对白| 国产精品一区久久| 尤物在线精品| 亚洲视频网在线直播| 亚洲欧美美女| 麻豆成人精品| 亚洲成色www8888| 在线视频一区观看| 久久国产精品久久久久久| 欧美成人一区二区三区| 国产精品成人午夜| 在线成人欧美| 亚洲午夜在线观看视频在线| 久久成人综合网| 亚洲第一页中文字幕| 亚洲五月六月| 欧美h视频在线| 国产日韩在线看| 日韩一区二区免费看| 欧美一区二区三区另类 | 久久久久国内| 亚洲精品久久| 欧美激情中文字幕一区二区| 午夜一级久久| 欧美三级视频在线| 欧美日韩综合| 国产精品大全| 国产一区二区丝袜高跟鞋图片| 欧美日韩国产在线看| 国产精品v亚洲精品v日韩精品| 国产精品一区二区你懂得| 国产区日韩欧美| 在线看国产日韩| 亚洲美女网站| 欧美一区高清| 欧美国产一区视频在线观看| 亚洲欧美日韩一区在线| 欧美国产日韩视频| 在线观看欧美精品| 久久久久在线观看| 性感少妇一区| 国产精品夜夜夜| 午夜在线精品偷拍| 亚洲婷婷综合久久一本伊一区| 免费观看成人| 亚洲国产mv| 久久综合一区二区| 欧美亚洲免费电影| 国产日韩欧美中文在线播放| 亚洲经典在线| 女人色偷偷aa久久天堂| 欧美在线观看一区二区三区| 国产精品一区二区三区免费观看| 亚洲网友自拍| 亚洲图片在区色| 国产精品毛片a∨一区二区三区|国 | 欧美在线3区| 国产精品色网| 午夜日韩av| 亚洲成色777777女色窝| 亚洲精品一区在线| 久久精品论坛| 国产啪精品视频| 在线中文字幕不卡| 欧美成人亚洲成人日韩成人| 欧美一区二区三区在线免费观看| 欧美日韩一区二区三区在线观看免| 国产综合色在线| 亚洲欧美精品一区| 亚洲激情欧美激情| 久久免费视频网站| 国产美女精品视频| 亚洲资源av| 亚洲黄色成人网| 美女91精品| 乱人伦精品视频在线观看| 国产精品国产三级国产aⅴ无密码| 日韩亚洲不卡在线| 亚洲一区在线观看免费观看电影高清| 国产精品久久久久9999高清| 销魂美女一区二区三区视频在线| 校园激情久久| 91久久在线| 亚洲天堂网在线观看| 激情综合网激情| 妖精成人www高清在线观看| 国产麻豆综合| 亚洲国产精品毛片| 国产精品一级久久久| 蜜臀91精品一区二区三区| 国产精品美女久久久久aⅴ国产馆| 久久久国产精品亚洲一区| 国产精品啊啊啊| 欧美成人一品| 国产精品亚洲片夜色在线| 欧美激情一区二区三区在线视频| 欧美午夜视频一区二区| 久久久久www| 欧美日韩黄色大片| 久久精品免费播放| 欧美大片91| 久久乐国产精品| 欧美亚一区二区| 亚洲盗摄视频| 一区视频在线| 亚洲影院在线观看| 一本色道久久综合亚洲精品高清 | 午夜精品视频一区| 亚洲美女视频在线免费观看| 欧美一区二区性| 午夜视频精品| 欧美视频精品一区| 欧美福利视频在线| 国内久久视频| 中文一区字幕| 亚洲天堂免费在线观看视频| 免费观看成人鲁鲁鲁鲁鲁视频| 久久精品国产第一区二区三区最新章节| 欧美日韩国产色综合一二三四 | 久久久久久欧美| 国产乱肥老妇国产一区二| 日韩午夜在线播放| 日韩视频在线观看国产| 久久影院亚洲| 美女视频一区免费观看| 国产亚洲一区二区在线观看 | 国产午夜精品一区二区三区欧美| 亚洲精品久久嫩草网站秘色| 亚洲国产欧美日韩精品| 欧美综合第一页| 久久九九久精品国产免费直播| 国产精品入口夜色视频大尺度| 一区二区三区成人精品| 老鸭窝毛片一区二区三区| 久久亚洲一区| 激情另类综合| 久久久夜精品| 欧美国产精品久久| 欧美色图五月天| 免播放器亚洲| 国产精品久久午夜夜伦鲁鲁| 欧美国产视频日韩| 国产日韩欧美另类| 中文亚洲字幕| 亚洲影视中文字幕| 欧美日韩国产影院| 欧美激情第三页| 亚洲三级影片| 欧美日韩三区| 亚洲永久字幕| 久久三级视频| 亚洲精品国产视频| 欧美日韩一区二区在线观看| 亚洲影院色无极综合| 久久人人97超碰人人澡爱香蕉| 永久免费毛片在线播放不卡| 欧美成人一区二区在线| 亚洲精品中文字幕在线| 亚洲一区二区视频在线观看| 国产精品视频一区二区高潮| 久久国产精品99国产| 亚洲国产黄色片| 欧美一区二区视频网站| 亚洲电影有码| 欧美日韩免费精品| 亚洲欧美电影在线观看| 久久综合伊人77777蜜臀| 99视频精品在线| 韩国女主播一区| 欧美特黄一级大片| 久久国产精品一区二区三区| 久久久噜噜噜| 亚洲国产影院|