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

上次說,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>
            国产精品一区在线播放| 久久久综合免费视频| 欧美精品一区二区精品网| 亚洲午夜羞羞片| 最新国产乱人伦偷精品免费网站| 亚洲欧美日韩精品久久亚洲区 | 国产人久久人人人人爽| 欧美日韩少妇| 欧美精品一区二区三区在线播放| 欧美在线三区| 久久婷婷影院| 欧美激情a∨在线视频播放| 久热精品视频在线免费观看| 久久精品91久久香蕉加勒比| 欧美在线啊v| 久久精品人人做人人综合| 午夜老司机精品| 久久成人免费视频| 久久婷婷激情| 免费短视频成人日韩| 欧美成人有码| 欧美久久久久中文字幕| 欧美日韩精品福利| 国产精品每日更新| 国产在线视频欧美| 亚洲国产成人不卡| 日韩视频―中文字幕| 一区二区免费看| 欧美一级久久久| 欧美日本一区二区视频在线观看| 欧美激情自拍| 国产精品国产三级国产| 国产欧美一区二区三区在线看蜜臀| 国产欧美一区二区三区视频| 精品盗摄一区二区三区| 亚洲人屁股眼子交8| 一区二区三区四区五区在线 | 亚洲国产激情| 国产精品99久久不卡二区| 午夜精品久久久久久久久久久久| 欧美在线你懂的| 亚洲电影观看| 亚洲天堂网在线观看| 欧美中文字幕视频在线观看| 欧美www视频| 国产精品视频成人| 亚洲国产视频a| 午夜日本精品| 亚洲国产成人精品女人久久久 | 欧美日韩精品一区二区| 国产日韩欧美在线观看| 最新国产精品拍自在线播放| 亚洲欧美另类在线| 欧美激情1区2区| 一本色道久久加勒比88综合| 欧美亚洲视频一区二区| 欧美日本乱大交xxxxx| 黄色欧美成人| 欧美亚洲一区二区在线观看| 亚洲观看高清完整版在线观看| 亚洲一区国产视频| 欧美精品综合| 亚洲国产精品久久久久| 国产综合香蕉五月婷在线| av成人免费观看| 免费成人av| 欧美在线高清视频| 国产精品伊人日日| 日韩午夜在线播放| 免费不卡中文字幕视频| 欧美一区91| 国产精品免费看片| 亚洲小少妇裸体bbw| 最新国产拍偷乱拍精品| 美女久久一区| 在线看欧美视频| 久久午夜激情| 久久se精品一区二区| 国产精品视频yy9099| 亚洲欧美日韩一区二区在线 | 国产日韩欧美三级| 亚洲国产精品久久久久久女王| 欧美在线短视频| 国产精品一区一区三区| 日韩网站在线| 欧美影院视频| 日韩亚洲欧美一区二区三区| 欧美在线一级va免费观看| 国内激情久久| 亚洲欧美日韩专区| 亚洲每日更新| 欧美一区免费视频| 91久久精品美女高潮| 久久嫩草精品久久久精品一| 亚洲福利视频网站| 一区二区高清在线| 欧美日韩直播| 亚洲影院免费观看| 亚洲国产精品一区二区三区| 欧美α欧美αv大片| 老司机精品视频一区二区三区| 欧美成人精品在线播放| 亚洲精品视频一区| 99re66热这里只有精品4| 欧美精品一区二| 性做久久久久久久久| 欧美一区二视频在线免费观看| 国语精品中文字幕| 亚洲大胆av| 国产精品日韩高清| 欧美暴力喷水在线| 欧美视频第二页| 久久手机免费观看| 欧美老女人xx| 久久天堂成人| 国产精品高潮在线| 老司机亚洲精品| 国产精品va在线播放我和闺蜜| 久久人人超碰| 欧美三级乱码| 老司机免费视频一区二区| 欧美三级在线视频| 欧美伊人精品成人久久综合97| 久久国产天堂福利天堂| 亚洲乱码日产精品bd| 欧美电影电视剧在线观看| 欧美视频一区二| 欧美高清视频免费观看| 国产精品日韩欧美一区二区三区| 免费视频一区| 国产精品夜夜夜| 亚洲国产精品传媒在线观看 | 欧美一级大片在线观看| 亚洲国产另类久久久精品极度| 亚洲国产一区在线| 国内精品久久久久久久97牛牛| 欧美搞黄网站| 国内成人精品2018免费看| 在线综合亚洲欧美在线视频| 国产精品一区二区久久久久| 亚洲国产欧美一区二区三区同亚洲 | 一区二区三区四区精品| 亚洲欧美精品在线观看| 99re在线精品| 蜜桃av久久久亚洲精品| 午夜精品国产| 欧美午夜一区| 99在线精品观看| 亚洲最新色图| 欧美中文字幕不卡| 欧美一级理论性理论a| 欧美视频日韩视频| 99国产精品一区| 日韩午夜av| 欧美大香线蕉线伊人久久国产精品| 久久久人成影片一区二区三区观看| 欧美视频中文字幕在线| 亚洲精品视频在线观看免费| 亚洲九九爱视频| 欧美精品免费播放| 亚洲国产成人porn| 日韩亚洲精品视频| 欧美精品成人91久久久久久久| 欧美国产极速在线| 尤物99国产成人精品视频| 久久精品在线观看| 奶水喷射视频一区| 亚洲国产欧美日韩精品| 鲁大师影院一区二区三区| 欧美成人xxx| 亚洲美女视频| 国产精品扒开腿做爽爽爽视频| 一区二区三区国产在线观看| 亚洲中字在线| 国产女主播一区二区| 亚洲欧美视频在线| 免费中文字幕日韩欧美| 国产三级欧美三级| 久久久久久久综合狠狠综合| 久久成人免费| 一区二区在线观看av| 欧美在线观看视频一区二区三区| 久久久久久久一区二区三区| 狠狠久久婷婷| 久久国内精品视频| 午夜一区不卡| 一区二区亚洲精品| 欧美精品v日韩精品v国产精品| 欧美大片在线看| 亚洲欧美视频在线观看| 亚洲精品一级| 在线观看91精品国产麻豆| 国产精品日韩专区| 欧美日韩hd| 欧美77777| 欧美激情网站在线观看| 亚洲美女视频| 亚洲在线视频| 亚洲免费观看| 美女网站久久|