1

すべての VARIATIONS WITH REPETITION を生成するための Java コードを持っている人はいますか?

順列と組み合わせの例はたくさんありますが、バリエーションは最も簡単なものでなければなりません...車輪を再発明するために時間を無駄にするのはばかげているように感じます (これには多くのコードが書かれている必要があります)。

VARIATIONS WITH REPETITION の例は次のようになります。

(tupletSize=3, input= A, B)
AAA, AAB, ABA, BAA, ABB, BAB, BBA, BBB

ありがとう!

4

4 に答える 4

9

これはそのまま機能し、学習するのが最も簡単です。

public class Main {
    public static void main(String args[]) {
        brute("AB", 3, new StringBuffer());
    }
    static void brute(String input, int depth, StringBuffer output) {
        if (depth == 0) {
            System.out.println(output);
        } else {
            for (int i = 0; i < input.length(); i++) {
                output.append(input.charAt(i));
                brute(input, depth - 1, output);
                output.deleteCharAt(output.length() - 1);
            }
        }
    }
}
于 2010-03-02T20:33:36.113 に答える
4
public class Main {

    public static void main(String[] args) throws IOException {
        LinkedList<char[]> items = new LinkedList<char[]>();
        char[] item = new char[3];
        char[] input = {'A', 'B'};
        rep(items, input, item, 0);


        for (char[] rep : items) {
            System.out.println(rep);
        }
    }

    private static void rep(LinkedList<char[]> reps, char[] input, char[] item, int count){
        if (count < item.length){
            for (int i = 0; i < input.length; i++) {
                item[count] = input[i];
                rep(reps, input, item, count+1);
            }
        }else{
            reps.add(item.clone());
        }
    }

}

次の出力を生成します: AAA AAB ABA ABB BAA BAB BBA BBB

大きな tupleSize によるスタック オーバーフローに注意してください。再帰アルゴリズム (このようなもの) は通常、反復バージョンよりも低速ですが、コーディングには非常に便利です。

于 2010-03-02T19:47:31.293 に答える
0

n-ary グレイ コードの原理を使用できます。

http://en.wikipedia.org/wiki/Gray_code#Constructing_an_n-bit_Gray_code

于 2012-10-04T20:24:06.173 に答える
0

ブルートフォースパスワードクラッカーの書き方

これは Java の実装ではありませんが、順列を行う部分は Java に簡単に移植できるはずです。

Python の知識がない状態で C に移植したところ、魅力的に機能しました。

于 2010-03-02T19:59:33.830 に答える