• <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>
            syhd142  
            日歷
            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789
            統計
            • 隨筆 - 23
            • 文章 - 122
            • 評論 - 31
            • 引用 - 0

            導航

            常用鏈接

            留言簿(2)

            隨筆檔案(23)

            文章分類(270)

            文章檔案(122)

            我的豆瓣

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

             
            據說經典DP,設opt[i][j]表示第二個基因序列的前i個基因和第一個基因序列的前j個匹配得到的最大值。
            那么可以得到轉移方程啊opt[i][j] = max(a[i-1][j-1]+table[b[i-1]][a[i- ]], opt[i-1][j]+table['-'][a[j]], opt[i][j-1]+table[b[i]]['-']);
            最后需要注意的就是邊界情況,即基因都匹配空的情況。
            #include <stdio.h>
            #include 
            <string.h>

            #define N 105
            #define MAX(a, b) (a > b ? a : b)

            int a[N][N];
            char s1[N], s2[N];

            int table[5][5= 
            {{
            5-1-2-1-3},
             {
            -15-3-2-4}, 
             {
            -2-35-2-2}, 
             {
            -1-2-25-1}, 
             {
            -3-4-2-10}};

            inline 
            int hash(char s)
            {
                
            if(s == 'A'return 0;
                
            if(s == 'C'return 1;
                
            if(s == 'G'return 2;
                
            if(s == 'T'return 3;
                
            if(s == '-'return 4;
            }

            int main()
            {
                
            int t, l1, l2;
                scanf(
            "%d"&t);
                
            while(t--)
                {
                    scanf(
            "%d %s"&l1, &s1);
                    scanf(
            "%d %s"&l2, &s2);
                    memset(a, 
            0sizeof(a));
                    
            for(int i = 0; i < l1; i++)
                    {
                        a[
            0][i + 1= a[0][i] + table[4][hash(s1[i])];
                    }
                    
            for(int i = 0; i < l2; i++)
                    {
                        a[i 
            + 1][0= a[i][0+ table[hash(s2[i])][4];
                    }
                    
            for(int i = 1; i <= l2; i++)
                    {
                        
            int x, y;
                        x 
            = hash(s2[i - 1]);
                        
            for(int j = 1; j <= l1; j++)
                        {
                            y 
            = hash(s1[j - 1]);
                            
            int t1, t2, t3;
                            t1 
            = a[i - 1][j - 1+ table[x][y];
                            t2 
            = a[i - 1][j] + table[x][4];
                            t3 
            = a[i][j - 1+ table[4][y];
                            a[i][j] 
            = MAX(t1, MAX(t2, t3));
                        }
                    }
                    printf(
            "%d\n", a[l2][l1]);
                }
                
            return 0;
            }
            posted on 2010-06-04 12:23 Fucker 閱讀(109) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPCDP
             
            Copyright © Fucker Powered by: 博客園 模板提供:滬江博客
            久久久久久亚洲Av无码精品专口| 国产精品成人久久久久三级午夜电影| 久久国产视屏| 色偷偷88欧美精品久久久| 狠狠色丁香久久婷婷综合| 久久精品99久久香蕉国产色戒| 久久成人精品视频| 久久人人爽人人爽人人片AV东京热| 亚洲乱码日产精品a级毛片久久| 中文字幕久久久久人妻| 99久久久久| 久久精品a亚洲国产v高清不卡| 久久久久婷婷| 99久久99久久久精品齐齐| 久久综合给合综合久久| 国内精品九九久久久精品| 午夜精品久久久久| 久久精品国产99久久久香蕉| 99国产欧美久久久精品蜜芽| 久久频这里精品99香蕉久| 国产精品久久久久一区二区三区| 嫩草伊人久久精品少妇AV| 久久亚洲精品无码VA大香大香| 99热热久久这里只有精品68| 午夜人妻久久久久久久久| 亚洲国产成人久久综合区| 久久se精品一区二区影院| 久久九九亚洲精品| 丁香五月网久久综合| 成人国内精品久久久久一区| 国产精品99久久久精品无码| 一本综合久久国产二区| 色天使久久综合网天天| 久久99精品久久久久久不卡| 99久久99久久精品国产片果冻 | 久久99国产亚洲高清观看首页| 久久天天躁狠狠躁夜夜躁2014| 香蕉99久久国产综合精品宅男自| 国产精品伦理久久久久久| 久久天天躁狠狠躁夜夜不卡 | 亚洲综合日韩久久成人AV|