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

                脫氧核糖核酸即常說的DNA,是一類帶有遺傳信息的生物大分子。它由4種主要的脫氧核苷酸(dAMP、dGMP、dCMT和dTMP)通過磷酸二酯鍵連接而成。這4種核苷酸可以分別記為:A、G、C、T。

                DNA攜帶的遺傳信息可以用形如:AGGTCGACTCCA.... 的串來表示。DNA在轉錄復制的過程中可能會發生隨機的偏差,這才最終造就了生物的多樣性。

                為了簡化問題,我們假設,DNA在復制的時候可能出現的偏差是(理論上,對每個堿基被復制時,都可能出現偏差):

              1. 漏掉某個脫氧核苷酸。例如把 AGGT 復制成為:AGT

                2. 錯碼,例如把 AGGT 復制成了:AGCT

                3. 重碼,例如把 AGGT 復制成了:AAGGT


                如果某DNA串a,最少要經過 n 次出錯,才能變為DNA串b,則稱這兩個DNA串的距離為 n。

                例如:AGGTCATATTCC 與 CGGTCATATTC 的距離為 2

                你的任務是:編寫程序,找到兩個DNA串的距離。


            【輸入、輸出格式要求】

                用戶先輸入整數n(n<100),表示接下來有2n行數據。

                接下來輸入的2n行每2行表示一組要比對的DNA。(每行數據長度<10000)

                程序則輸出n行,表示這n組DNA的距離。

                例如:用戶輸入:
            3
            AGCTAAGGCCTT
            AGCTAAGGCCT
            AGCTAAGGCCTT
            AGGCTAAGGCCTT
            AGCTAAGGCCTT
            AGCTTAAGGCTT

                則程序應輸出:
            1
            1
            2

            結題思路:參閱百度百科http://baike.baidu.com/view/2020247.htm
            代碼如下:

            import java.util.*;


            public class Main {
                
                
                
            static String instr0;
                
            static String instr1;
                
            public static void main(String[] args)
                
            {
                    Scanner sc 
            = new Scanner(System.in);
                    
            int N = sc.nextInt();
                    sc.nextLine();
                    
            for(int ii = 0; ii < N; ii++){
                        instr0 
            = sc.nextLine();
                        instr1 
            = sc.nextLine();
                        
            int rs = pro();
                        System.out.println(rs);
                    }

                    
                }

                
            static int pro(){
                    
            int[][] dis = new int[instr0.length()][instr1.length()];
                    
            for(int i = 0; i < instr0.length(); i++)
                        dis[i][
            0= i;
                    
            for(int j = 0; j < instr1.length(); j++)
                        dis[
            0][j] = j;
                    
            for(int i = 1; i < instr0.length(); i++){
                        
            for(int j = 1; j < instr1.length(); j++){
                            
            int cost = 0;
                            
            if(instr0.charAt(i) != instr1.charAt(j))
                                cost 
            = 1;
                            dis[i][j] 
            = min3(dis[i - 1][j] + 1, dis[i][j - 1+ 1
                                    dis[i 
            - 1][j - 1+ cost);
                        }

                    }

                    
            return dis[instr0.length() - 1][instr1.length() - 1];
                    
                }

                
            static int min3(int a, int b, int c){
                    
            return Math.min(Math.min(a, b), c);
                }


                
            }


             

            posted on 2013-07-09 19:26 小鼠標 閱讀(398) 評論(0)  編輯 收藏 引用 所屬分類: Java基礎練習
            <2011年8月>
            31123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            隨筆分類(111)

            隨筆檔案(127)

            friends

            最新評論

            • 1.?re: 線段樹
            • 是這個樣子的,所以在OJ有時候“卡住”了也不要太灰心,沒準真的不是自己的原因呢。
              加油,祝你好運啦!
            • --小鼠標
            • 2.?re: 線段樹
            • 對于編程競賽來說,Java所需時間一般為C/C++的兩倍。合理的競賽給Java的時間限制是給C/C++的兩倍。
            • --傷心的筆
            • 3.?re: poj1273--網絡流
            • 過來看看你。
            • --achiberx
            • 4.?re: (轉)ubuntu11.10無法啟動無線網絡的解決方法
            • 膜拜大神。。查了一個下午資料終于在這里解決了問題。。神牛說的區域賽難道是ACM區域賽。。?
            • --Hang
            • 5.?re: 快速排序、線性時間選擇
            • 博主,謝謝你的文章。你的方法可以很好的處理分區基準在數組中重復的情況,書上的方法遇到這種輸入會堆棧溢出。書上給出了解釋但給的方法貌似不簡潔。
            • --lsxqw2004

            閱讀排行榜

            国产精品99久久久久久宅男小说| 久久99久久99小草精品免视看| 精品久久久久国产免费| 久久久久一级精品亚洲国产成人综合AV区 | 久久精品国产亚洲av影院| 色8久久人人97超碰香蕉987| 99热成人精品热久久669| 久久精品一区二区三区中文字幕 | 久久亚洲精品国产精品婷婷| 午夜久久久久久禁播电影| 精品久久久久久国产| 四虎国产精品成人免费久久| 72种姿势欧美久久久久大黄蕉| 久久精品无码一区二区app| 午夜欧美精品久久久久久久| 久久久久人妻精品一区三寸蜜桃| 久久九九久精品国产免费直播| 久久免费美女视频| 久久99热只有频精品8| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 精品午夜久久福利大片| 久久人人青草97香蕉| 国产精品欧美久久久久天天影视| 亚洲日韩中文无码久久| 一级做a爰片久久毛片免费陪| 国产精品成人精品久久久| 久久久久99精品成人片直播| 免费久久人人爽人人爽av| 久久e热在这里只有国产中文精品99 | 久久精品国产一区二区三区| 国产∨亚洲V天堂无码久久久 | 久久久久久狠狠丁香| 久久66热人妻偷产精品9| 亚洲精品无码久久久久sm| 久久久精品久久久久影院| 久久久久亚洲AV无码专区网站| 91超碰碰碰碰久久久久久综合| 99精品久久久久中文字幕| 国产精品久久国产精麻豆99网站 | 久久国产精品久久| 韩国三级大全久久网站|