• <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>
            voip
            風的方向
            厚德致遠,博學敦行!
            posts - 52,comments - 21,trackbacks - 0
                   問題描述:給定序列X={x1,x2,..xn}和Y={y1,y2...ym},求一個Z={z1,z2,..zk}序列是X,Y的最長公共子序列!!

                  書上描述的已經(jīng)十分詳細了,而且容易理解。通過定義c[i][j]用于記錄Xi和Yi的最長公共子序列的長度,從而遞推得到結(jié)果。

            遞推方程如下:
                             c[i][j]=0,i=0,j=0;    c[i][j]=c[i-1][j-1]+1,xi=yj;     c[i][j]=max(c[i-1][j],c[i][j-1]),xi!=yj; (不知道怎么輸出大括號,悲劇啊!)

            代碼如下:
            #include<stdio.h>
            void LCSLength(int m,int n,char *x,char *y,int c[][100],int b[][100])
            {
                
            int i,j;
                
            for(i=1;i<=m;i++) c[i][0]=0;                        //當i==0或者j==0時,代表其中一個序列為空,c[i][j]當然為0
                for(j=1;j<=n;j++) c[0][j]=0;

                
            for(i=1;i<=m;i++)                                    //二重循環(huán)
                    for(j=1;j<=n;j++)
                    
            {
                        
            if(x[i]==y[j])
                        
            {
                            c[i][j]
            =c[i-1][j-1]+1;
                            b[i][j]
            =1;
                        }

                        
            else
                        
            {
                            
            if(c[i-1][j]>=c[i][j-1])
                            
            {
                                c[i][j]
            =c[i-1][j];
                                b[i][j]
            =2;
                            }

                            
            else
                            
            {
                                c[i][j]
            =c[i][j-1];
                                b[i][j]
            =3;
                            }

                        }

                    }

            }


            void LCS(int i,int j,char x[],int b[][100])    //遞歸求得最長子序列
            {
                
            if(i==0||b==0)
                    
            return;
                
            if(b[i][j]==1)
                
            {
                    LCS(i
            -1,j-1,x,b);
                    printf(
            "%c",x[i]);
                }

                
            else if(b[i][j]==2)
                    LCS(i
            -1,j,x,b);
                
            else 
                    LCS(i,j
            -1,x,b);
            }


            int main()
            {
                
            char x[100],y[100];
                
            int i,j;
                
            int c[100][100],b[100][100];
                scanf(
            "%s %s",x+1,y+1);
                c[
            0][0]=0;
                LCSLength(
            7,6,x,y,c,b);
                
            for(i=0;i<8;i++)
                
            {
                    
            for(j=0;j<7;j++)
                    
            {
                        printf(
            "%d ",c[i][j]);
                    }

                    printf(
            "\n");
                }

                LCS(
            7,6,x,b);
                printf(
            "\n");
                
            return 0;
            }
            運行結(jié)果:


            posted on 2010-09-04 23:17 jince 閱讀(340) 評論(0)  編輯 收藏 引用 所屬分類: 算法設計與分析
            哈哈哈哈哈哈
            久久天天躁狠狠躁夜夜不卡| 久久精品国产免费观看| 国产福利电影一区二区三区久久久久成人精品综合 | 综合网日日天干夜夜久久| 久久久av波多野一区二区| 久久久91精品国产一区二区三区 | 久久久久久久久波多野高潮| 久久久久国产精品麻豆AR影院 | 精品久久国产一区二区三区香蕉| 久久精品国产一区二区三区| 久久人人爽人人人人爽AV| 国产精品99久久免费观看| 7国产欧美日韩综合天堂中文久久久久| 久久免费99精品国产自在现线| 中文字幕久久波多野结衣av| 久久精品国产免费| 久久精品国产男包| 国内精品免费久久影院| 久久午夜无码鲁丝片| 久久艹国产| 26uuu久久五月天| 国产成人精品久久免费动漫| 一本一本久久aa综合精品 | 婷婷久久香蕉五月综合加勒比| 久久成人国产精品二三区| 亚洲中文久久精品无码ww16| 久久久久人妻一区精品色 | 亚洲精品无码久久久久久| 九九热久久免费视频| 久久国产乱子伦免费精品| 久久婷婷五月综合97色直播| 激情五月综合综合久久69| 秋霞久久国产精品电影院| WWW婷婷AV久久久影片| 色欲综合久久躁天天躁蜜桃| 亚洲精品乱码久久久久久不卡| 久久99热这里只有精品国产| 久久93精品国产91久久综合| 国内精品久久久久久不卡影院| 国产精自产拍久久久久久蜜| 精品无码久久久久久国产|