我的算法學習之路-算法題-迴環變位

迴環變位

算法(第四版)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;
    }
}

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

鏈接:容易想複雜的"迴環變位"

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


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章