java - 如果字符串大于 6 个字符,代码会给出重复值。适合 1-6 个字符的字符串...

标签 java

public class PossibleCombination {

     public static void comb(String s) {
       int N = s.length();
       char[] a = new char[N];
       for (int i = 0; i < N; i++)
           a[i] = s.charAt(i);
       comb(a, N);
    }

    private static void comb(char[] a, int n) {
        if (n == 1) {
            System.out.println( a);
            return;
            }
        for (int i = 0; i < n; i++) {
            swap(a, i, n-1);
            comb(a, n-1);
            swap(a, i, n-1);
            }
    }  
    private static void swap(char[] a, int i, int j) {
        char c;
        c = a[i]; 
        a[i] = a[j]; 
        a[j] = c;
    }

    public static void main(String[] args) {

       String alphabet = "sparowsd";
       System.out.println();
       comb(alphabet);
    }  
}

我必须进行哪些更改才能使程序不会给出重复的值?

我的代码给了我重复的值(如果字符串大于 6 个字符)...对于 1-6 个字符的字符串没问题...我需要在哪里进行更改? 谢谢!

最佳答案

您的程序会生成重复项,但这没关系,因为字符串“password”中有两个“s”字符。我很确定,这就是埃利奥特·弗里施的意思。在字符串“12345678”上尝试您的程序。它不应在其上生成任何重复项。但是,如果您在字符串“12345671”上尝试它,它会,因为其中有两个字符“1”。所以你的程序看起来不错,它生成输入字符串的所有排列。

如果你想消除重复项,你需要不同的算法。试试这个。

http://en.wikipedia.org/wiki/Permutations#Generation_in_lexicographic_order

关于java - 如果字符串大于 6 个字符,代码会给出重复值。适合 1-6 个字符的字符串...,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20304991/

相关文章:

java - Tapestry 4 contrib表多次调用getModel()

java - 用 C# 解密用 Java 加密的密码

java - web.xml 文件丢失

java - 根据子串对字符串进行排序

java - 这不会直接突破 if 语句吗?

java - 最终变量赋值错误

java - 类、接口(interface)或枚举预期错误?

java - 由字符串数组填充的 JComboBox(使用 for 循环)未出现

java - 如何从字符串中删除最后一个字符?

java - 带日期的 mongo 查询无法按预期工作