• <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)  編輯 收藏 引用 所屬分類: 算法設計與分析
            哈哈哈哈哈哈
            一本一本久久A久久综合精品| 国产成人久久激情91 | 无码任你躁久久久久久老妇App| 亚洲国产精品无码久久青草| 中文精品99久久国产 | 午夜不卡888久久| 无码任你躁久久久久久老妇App| 激情伊人五月天久久综合| 精品乱码久久久久久夜夜嗨| 亚洲va国产va天堂va久久| 久久精品国产福利国产琪琪| 久久久免费精品re6| 日本加勒比久久精品| 亚洲综合精品香蕉久久网97| 77777亚洲午夜久久多喷| 久久久久这里只有精品 | 99久久精品免费看国产| 亚洲国产精品久久66| 久久最近最新中文字幕大全 | 久久香综合精品久久伊人| 国产99久久九九精品无码| 日韩AV无码久久一区二区| 国产一区二区久久久| 亚洲Av无码国产情品久久| 精品国产乱码久久久久久浪潮| 激情伊人五月天久久综合| 久久精品亚洲精品国产色婷| 久久天天躁夜夜躁狠狠躁2022| 欧美久久天天综合香蕉伊| 理论片午午伦夜理片久久| 久久精品国产色蜜蜜麻豆| 国内精品久久久久久久亚洲| 国产精品美女久久久| 狠狠色丁香久久综合婷婷| 精品一区二区久久久久久久网站| 日韩精品久久无码人妻中文字幕| 久久棈精品久久久久久噜噜| 中文字幕热久久久久久久| 亚洲第一永久AV网站久久精品男人的天堂AV| 狠狠综合久久综合中文88| 久久精品这里只有精99品|