• <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基礎練習
            <2012年3月>
            26272829123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            常用鏈接

            隨筆分類(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

            閱讀排行榜

            草草久久久无码国产专区| 青青草原综合久久大伊人| 久久综合综合久久97色| 久久精品国产99久久丝袜| 久久国产欧美日韩精品| 丁香久久婷婷国产午夜视频| 欧美精品丝袜久久久中文字幕 | 国产亚洲精久久久久久无码AV| 久久久精品无码专区不卡| 久久久亚洲欧洲日产国码二区| 久久精品视屏| 国产精品对白刺激久久久| 狠狠色丁香久久婷婷综合蜜芽五月| 97热久久免费频精品99| 久久久精品国产免大香伊 | 欧美va久久久噜噜噜久久| 久久露脸国产精品| 国产 亚洲 欧美 另类 久久| 婷婷久久香蕉五月综合加勒比| 欧美日韩精品久久久久| 88久久精品无码一区二区毛片| 久久亚洲精品国产精品| 久久精品国产乱子伦| 欧美日韩精品久久久久| 久久噜噜久久久精品66| 久久久91人妻无码精品蜜桃HD| 久久香蕉国产线看观看乱码| 国内精品久久久久影院日本| 久久亚洲AV成人出白浆无码国产 | 久久天天日天天操综合伊人av| 久久免费视频观看| 色综合久久久久| 国产激情久久久久影院小草| 久久国产精品-国产精品| 久久久久久久尹人综合网亚洲| 久久精品国产亚洲一区二区| 97超级碰碰碰碰久久久久| 日韩亚洲欧美久久久www综合网| 99久久精品免费看国产免费| 狠狠色综合久久久久尤物| 亚洲美日韩Av中文字幕无码久久久妻妇|