gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-01 13:46:50 25 4
gpt4 key购买 nike

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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com