国产探花免费观看_亚洲丰满少妇自慰呻吟_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;    }}

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

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

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 松滋市| 曲麻莱县| 天水市| 金溪县| 蛟河市| 忻城县| 隆回县| 台中市| 安图县| 罗田县| 资源县| 沈阳市| 平湖市| 临沭县| 通化市| 叙永县| 虹口区| 临城县| 巴东县| 霍林郭勒市| 洪雅县| 凭祥市| 西宁市| 清苑县| 根河市| 凤台县| 远安县| 平湖市| 家居| 皮山县| 石家庄市| 龙岩市| 寻乌县| 合山市| 枝江市| 九龙城区| 永和县| 建德市| 武陟县| 大英县| 都匀市|