0

この宿題は、小文字の az のみで作られた、指定された長さ n (無制限で不明!) のパスワードを解読するための再帰的な方法を作成することです。

ランダムなパスワードを作成するクラス「Password」は次のとおりです。

import java.util.Random;

public class Password {
private String _password = "";

public Password(int length) {
    Random generator = new Random();
    for (int i = 0; i < length; ++i) {
        this._password = this._password + (char) (generator.nextInt(26) + 97);
    }
}

public boolean isPassword(String st) {
    return st.equals(this._password);
}

public String getPassword() {
    return this._password;
  }
}  

質問の詳細は次のとおりです。「コードを「クラック」する静的再帰メソッドを 作成する必要がありpublic static String findPassword(Password p, int length)ます。メイン メソッドの例を次に示します。

public class Main {                                                                                                     
    public static void main(String[] args) {                                                                            
        Password p = new Password(5);                                                                                   
        System.out.println(p.getPassword());                                                                            
        System.out.println(Ex14.findPassword(p, 5));                                                                    
    }                                                                                                                   
}       

重要事項:

  1. メソッドは、ANY ループを使用せずに、再帰的でなければなりません。
  2. getPassword メソッドは使用できません。
  3. String クラスのメソッドを使用する場合は、charAt、substring、equals、lengthのみを使用できます。
  4. オーバーロードを使用することはできますが、他の方法を使用することはできません。(String.replace/String.replaceall は使用できません)
  5. 静的 (グローバル) 変数は使用できません。
  6. 配列は使用できません。"

これは私が今まで持っていたものですが、明らかにうまくいきません。:\

public static String findPassword(Password p, int length) {
    return findPassword(p, length, "", 'a');
}

public static String findPassword(Password p, int length, String testPass, char charToChange) {
    int currDig = testPass.length() - 1;
    if (p.isPassword(testPass))
        return testPass;
    if (length == 0) // There is no password.
        return ""; // Returns null and not 0 because 0 is a password.
    if (length > testPass.length())
        return findPassword(p, length, testPass + charToChange, charToChange);
    if (testPass.length() == length) {
        //TODO if charToChange is 'z', then make it the one before it '++', and reset everything else to a.
        //if (charToChange == 'z') {
            // charToChange = 'a';
            // String newString = testPass.substring(0, currDig-1) +
            // (charToChange++)
            // +testPass.substring(currDig+1,testPass.length()-1);
            System.out.println("it's  z");
            // TODO currDig --;
            // String newerString = testPass.substring(0, currDig - 1)
            // + (char) (testPass.charAt(testPass.length() - 1) - 25);
            // currDig--;
        }
        return "";  
}

どうもありがとうございました!とても有難い!- トリプルS

4

0 に答える 0