• <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 小鼠標 閱讀(404) 評論(0)  編輯 收藏 引用 所屬分類: Java基礎練習
            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            常用鏈接

            隨筆分類(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久久精品国产精品青草| 国产A级毛片久久久精品毛片| 欧美喷潮久久久XXXXx| 狠狠精品久久久无码中文字幕| 日韩中文久久| 久久综合给合久久狠狠狠97色| 亚洲AV无码久久精品蜜桃| 久久久久久久久久免免费精品| 久久人妻AV中文字幕| 亚洲国产成人久久综合碰碰动漫3d | 亚洲国产精品无码久久久久久曰| 久久综合久久综合九色| 狠狠色丁香久久婷婷综合蜜芽五月 | 免费精品国产日韩热久久| 久久天天躁狠狠躁夜夜96流白浆| 97精品依人久久久大香线蕉97| 2022年国产精品久久久久| 久久免费视频1| 国产成人99久久亚洲综合精品| 色婷婷综合久久久久中文一区二区| 国产精品综合久久第一页| 久久精品国产亚洲av日韩| 青青草原精品99久久精品66| 久久久久人妻一区精品| 国产精品一区二区久久| 91久久成人免费| 久久无码人妻一区二区三区| 女人高潮久久久叫人喷水| 亚洲欧洲久久久精品| 久久性生大片免费观看性| 久久亚洲高清综合| 国产综合成人久久大片91| 国产精品99久久久久久董美香| 久久99亚洲网美利坚合众国| 成人资源影音先锋久久资源网| 久久午夜无码鲁丝片秋霞| 久久综合亚洲鲁鲁五月天| 久久99热这里只有精品国产| 亚洲AV日韩精品久久久久久| 久久久久亚洲AV成人片| 久久99国产综合精品女同|