国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

我的算法學習之路

2019-11-08 01:43:39
字體:
來源:轉載
供稿:網友

1.回環變位

算法(第四版)1.2.6題:

如果字符串s中的字符循環移動任意位置之后能夠得到另一字符串t,那么s就被稱為t的回環變位。例如,ACTGACG 就是 TGACGAC 的一個回環變位,反之亦然。判定這個條件在基因組序列中的研究是十分重要的。編寫一個算法檢查兩個給定的字符串s和t是否互為回環變位。

跟下面的一個哥們兒想的一樣,想著用雙循環,i ,j什么的,我比較笨,真的嘗試著寫了寫,結果浪費了一個多小時,套了兩個循環加一個if語句,最后還沒寫出來,吐血……

最后在網上找了找答案,發現有非常簡單的方法,一行代碼就能實現,有兩種:

第一種是調用String類的cotains(String s)方法,這個方法是判斷調用方法的對象(字符串類型)是否包含字符串s,返回值是boolean類型的,如果包含返回true,不包含則返回false;

代碼是:

public class CircularRotation{    public static void main(String[] args){        String s = "HAHAWORLD";        String t = "WORLDHAHA";        boolean b = isCircularRotation(s, t);        StdOut.PRintln(b);    }    public static boolean isCircularRotation(String s, String t){       return (s.length()==t.length()) && (s+s).contains(t);    }}

第二種是通過String類下的contact(String s)方法和indexOf(String t)方法的組合實現的,,contact()方法是將調用方法的對象(字符串類型)跟傳入的字符串s連接起來,返回一個新的字符串,indexOf()方法則是“返回指定子字符串在此字符串中第一次出現處的索引。”“如果字符串參數作為一個子字符串在此對象中出現,則返回第一個這種子字符串的第一個字符

的索引;如果它不作為一個子字符串出現,則返回 -1。”通過判斷返回的值是否大于0來判斷字符串t是否存在于調用方法的字符串中。

代碼是:

public class CircularRotation{    public static void main(String[] args){        String s = "HAHAWORLD";        String t = "WORLDHAHA";        boolean b = isCircularRotation(s, t);        StdOut.println(b);    }    public static boolean isCircularRotation(String s, String t){       return (s.length() == t.length()) && (s.concat(s).indexOf(t) >= 0);       }}正常邏輯實現寫出來的代碼如下,其中參考了蘑菇君520的思路,在此表示感謝,開源的力量是偉大的:

public class CircularRotation{    public static void main(String[] args){        String s = "HAHAWORLD";        String t = "WORLDHAHA";        boolean b = isCircularRotation(s, t);        StdOut.println(b);    }    public static boolean isCircularRotation(String s, String t)            if(s.length()!=t.length()){            StdOut.println("Length not equal");            return false;        }        for(int i=0; i<s.length(); i++){            String ss = s.substring(0, i);            String sss = s.substring(i, s.length());            if((sss + ss).equals(t))                return true;        }        StdOut.println("Not equal");        return false;    }}

以下是參考所用的兩篇博客,在此表示感謝!

鏈接:容易想復雜的"回環變位"

鏈接:判斷字符串回環變位


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 根河市| 湘潭市| 抚顺县| 那曲县| 华容县| 怀远县| 文化| 浮梁县| 湟源县| 南投市| 津南区| 响水县| 黑龙江省| 团风县| 京山县| 平远县| 全南县| 射洪县| 和政县| 孝感市| 英吉沙县| 万源市| 嘉祥县| 杨浦区| 万山特区| 谷城县| 淄博市| 深圳市| 莎车县| 中卫市| 蓬安县| 正阳县| 阳泉市| 纳雍县| 邵阳市| 玉田县| 南平市| 湘潭县| 寻乌县| 沂南县| 文成县|