Код для вариаций с повторением (комбинаторика)? - PullRequest
2 голосов
/ 02 марта 2010

Есть ли у кого-нибудь Java-код для генерации всех вариаций с повторением?

Существует множество примеров перестановок и комбинаций, и вариации должны быть самыми простыми ... Глупо тратить время на то, чтобы заново изобретать колесо (для этого должно быть написано много кода).

Пример ВАРИАЦИЙ С ПОВТОРЕНИЕМ может быть таким:

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

Спасибо!

Ответы [ 4 ]

9 голосов
/ 02 марта 2010

Это работает как есть, и вам легче всего учиться.

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);
            }
        }
    }
}
4 голосов
/ 02 марта 2010
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 В

Остерегайтесь переполнения стека с большим tupleSize. Рекурсивные алгоритмы (как этот) обычно медленнее, чем итерационные версии, но они очень удобны для кода

0 голосов
/ 05 октября 2012

Вы можете использовать принцип n-арного кода Грея

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

0 голосов
/ 02 марта 2010

Как написать взломщик паролей

Хотя это не реализация Java, часть, выполняющая перестановки, должна быть довольно легко портироваться в Java.

Я портировал его на C, не зная Python, и он работал как шарм.

...