• <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的最長公共子序列!!

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

            遞推方程如下:
                             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++)                                    //二重循環
                    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;
            }
            運行結果:


            posted on 2010-09-04 23:17 jince 閱讀(324) 評論(0)  編輯 收藏 引用 所屬分類: 算法設計與分析
            哈哈哈哈哈哈
            国产精品免费久久| 久久精品无码一区二区无码| 久久er国产精品免费观看8| 7国产欧美日韩综合天堂中文久久久久| 国产精品一久久香蕉国产线看 | 国产午夜精品理论片久久| 久久精品综合一区二区三区| 久久91精品国产91久| 久久精品人人做人人爽电影蜜月 | 人妻少妇精品久久| 国产精品99久久免费观看| 国产A级毛片久久久精品毛片| 伊人热热久久原色播放www| 久久九九全国免费| 亚洲中文字幕无码久久2020| 97久久精品人人做人人爽| 中文无码久久精品| 欧美精品九九99久久在观看| 日韩av无码久久精品免费| 日本加勒比久久精品| 伊人久久综合热线大杳蕉下载| 综合久久精品色| 精品久久国产一区二区三区香蕉| 久久综合久久自在自线精品自| 国产精品成人久久久久久久| 久久香蕉超碰97国产精品| 国内精品久久久久影院薰衣草 | 国产农村妇女毛片精品久久| 久久精品国产亚洲麻豆| 久久精品夜夜夜夜夜久久| 亚洲精品无码久久千人斩| 亚洲国产精品综合久久一线| 国产精品免费久久久久久久久 | 国产91色综合久久免费| 久久久久99精品成人片试看| 久久久久亚洲AV无码专区首JN| 色播久久人人爽人人爽人人片aV| 国产精品va久久久久久久| 国产精品99久久久久久猫咪| 久久精品这里热有精品| 国产一区二区精品久久|