• <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>

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評(píng)論 - 47, 引用 - 0
            數(shù)據(jù)加載中……

            POJ 1934 Trip 打印出所有的最長(zhǎng)公共子序列

            這題很難,我只寫(xiě)出了一個(gè)TLE的版本。
            后來(lái)找了解題報(bào)告,只找到了一個(gè),就是這位alpc43大牛的版本:
            http://hi.baidu.com/alpc43/blog/item/95184e03a5fef4e209fa932d.html

            這個(gè)代碼很牛逼!
            它的思路是:

            1)首先按照常規(guī)的方法求出最長(zhǎng)公共子序列的長(zhǎng)度
            也就是用O(MN)的那個(gè)動(dòng)態(tài)規(guī)劃,結(jié)果放在二維數(shù)組dp里
            dp[i][j] = { 字串a(chǎn)的1~i部分與字串b的1~j部分的最長(zhǎng)公共子序列的長(zhǎng)度 }
            2)求輔助數(shù)組
            last1[i][j] = { 到下標(biāo)i為止,字符j在字串a(chǎn)中最后一次出現(xiàn)的下標(biāo) }
            last2[i][j] = { 到下標(biāo)i為止,字符j在字串b中最后一次出現(xiàn)的下標(biāo) }
            3)枚舉最長(zhǎng)公共字串的每一個(gè)字符
            從最后一個(gè)字符開(kāi)始枚舉
            比如說(shuō)現(xiàn)在枚舉最后一個(gè)字符是'C'的情況。
            那么 'CDCD' 與 'FUCKC' 這兩個(gè)字串。
            一共有 (0, 2) (0, 4)  (2, 2)  (2. 4) 這四種可能。
            很明顯前三個(gè)是可以舍棄的,因?yàn)榈谒膫€(gè)優(yōu)于前三個(gè),為后續(xù)的枚舉提供了更大的空間。
            last數(shù)組正好是用來(lái)做這個(gè)的。
            4)排序輸出
            代碼里用了stl的set。
            注意,由于剛剛的枚舉過(guò)程是針對(duì)每個(gè)字符,所以是不用判重的。

            這個(gè)思路非常之牛逼!

            #include <stdio.h>
            #include 
            <string.h>
            #include 
            <math.h>
            #include 
            <string>
            #include 
            <set>;

            using namespace std;

            const int MAXLEN=100;
            char s1[MAXLEN];
            char s2[MAXLEN];
            int len1,len2;
            int dp[MAXLEN][MAXLEN];
            int last1[MAXLEN][27];
            int last2[MAXLEN][27];
            int longest;
            char temp[MAXLEN];
            set<string> SET;
            void input()
            {
                scanf(
            "%s %s",&s1[1],&s2[1]);

            }

            inline 
            int maxab(int a,int b)
            {
                
            if(a>b) return a;
                
            return b;
            }


            inline 
            void find(int x,int y,int len)
            {
                
            if(len<=0)
                
            {
                    
            //printf("%s\n",&temp[1]);
                    SET.insert(&temp[1]);
                    
            return ;
                }

                
            int i,j;
                
            if(x>0 && y>0)
                
            {
                    
            for(i=0;i<26;i++)
                    
            {
                        
            int t1=last1[x][i];
                        
            int t2=last2[y][i];
                        
            if(dp[t1][t2]==len)
                        
            {
                            temp[len]
            ='a'+i;
                            find(t1
            -1,t2-1,len-1);
                        }

                    }

                }

            }

            void solve()
            {
                
            int i,j,k;
                len1
            =strlen(&s1[1]);
                len2
            =strlen(&s2[1]);
                
            for(i=0;i<=len1;i++)
                    dp[i][
            0]=0;
                
            for(i=0;i<=len2;i++)
                    dp[
            0][i]=0;
                
            for(i=1;i<=len1;i++)
                    
            for(j=1;j<=len2;j++)
                    
            {
                        
            if(s1[i]==s2[j])
                            dp[i][j]
            =dp[i-1][j-1]+1;
                        
            else dp[i][j]=maxab(dp[i-1][j],dp[i][j-1]);
                    }

                    longest
            =dp[len1][len2];

                    
            for(j=0;j<26;j++)
                        
            for(i=0;i<=len1;i++)
                            last1[i][j]
            =0;
                    
            for(j=0;j<26;j++)
                        
            for(i=0;i<=len2;i++)
                            last2[i][j]
            =0;
                    
            for(i=1;i<=len1;i++)
                    
            {
                        
            for(j=0;j<26;j++)
                        
            {
                            
            if(s1[i]=='a'+j)
                                last1[i][j]
            =i;
                            
            else last1[i][j]=last1[i-1][j];
                        }

                    }

                    
            for(i=1;i<=len2;i++)
                    
            {
                        
            for(j=0;j<26;j++)
                        
            {
                            
            if(s2[i]=='a'+j)
                                last2[i][j]
            =i;
                            
            else last2[i][j]=last2[i-1][j];
                        }

                    }

                    temp[longest
            +1]='\0';
                    find(len1,len2,longest);
                    
            set<string>::iterator it;
                    
            for(it=SET.begin();it!=SET.end();it++)
                    
            {
                        printf(
            "%s\n",(*it).c_str());
                    }

            }

            int main()
            {
                freopen(
            "e:\\in.txt""r", stdin);

                input();
                solve();
                
            return 0;
            }

            posted on 2010-09-27 14:30 糯米 閱讀(2007) 評(píng)論(0)  編輯 收藏 引用 所屬分類: POJ

            久久精品亚洲精品国产色婷| 亚洲午夜久久久久久久久电影网| 精品久久亚洲中文无码| 精品久久久无码21p发布| 国内精品九九久久久精品| 久久精品综合一区二区三区| 国产69精品久久久久久人妻精品| MM131亚洲国产美女久久| 久久精品中文字幕一区| 国内精品久久久久久99| 噜噜噜色噜噜噜久久| 日本久久久精品中文字幕| 色成年激情久久综合| 久久人人添人人爽添人人片牛牛| 国内精品久久久人妻中文字幕| 久久亚洲国产精品五月天婷| 97r久久精品国产99国产精| 亚洲国产成人久久一区WWW| 久久久精品午夜免费不卡| 国产成人综合久久精品红| 国产精品成人99久久久久 | 青青青青久久精品国产h久久精品五福影院1421 | 77777亚洲午夜久久多喷| 国产精品免费看久久久香蕉| 一本色道久久综合狠狠躁| 污污内射久久一区二区欧美日韩 | 精品乱码久久久久久久| 少妇无套内谢久久久久| 国产精品美女久久久免费| 国产精品久久国产精麻豆99网站| 国产99久久久国产精品小说| 久久久免费观成人影院 | 久久综合狠狠综合久久激情 | 色欲久久久天天天综合网| 精品国产青草久久久久福利| 亚洲欧洲久久久精品| 欧美一区二区久久精品| 久久人人青草97香蕉| 亚洲精品tv久久久久久久久| 色综合久久无码五十路人妻| 99久久99久久|