字符串数组的Java置换
我试图找到将字符串数组与两个元素组合的所有可能选项。比方说,数组有两个元素{“we”,“are”}。输出应该是:“我们”“是”“我们是”“我们是” 我可以通过一些搜索来整理以下代码:
public class Main {
public static void main(String[] args) {
String[] strings = {"we", "are"};
final int maxbit = 1 << strings.length;
for (int p = 0; p < maxbit; p++) {
String finalString = "";
for (int i = 0; i < strings.length; i++) {
if ((1 << i & p) > 0) {
finalString += strings[i] + " ";
}
}
System.out.println(finalString);
}
}
我的问题是,我缺少一个解决方案,结果如下:“我们”“是”“我们是”。 所以我缺少了“are-we”选项,我是否需要使用递归来解决这个问题,或者是否可以修改此代码以显示剩余的选项
更新:在答案的帮助下找到解决方案
public static void main(String[] args) {
String[] test = { "are", "we"};
language(test.length, test, "");
}
private static void language(final int n, final String[] syllables, final String currentWord) { // example of N = 3
if (n == 0) {
System.out.println(currentWord);
} else {
for (int i = 0; i < syllables.length; i++) {
if (currentWord.equals(syllables[i])){
language(n - 1, syllables, "" + syllables[i]);
}else{
language(n - 1, syllables, currentWord + syllables[i]);
}
}
}
}
# 1 楼答案
我查看了一会儿,发现了两种基于代码的方法:
这将打印出每个排列一次,并且不必包含所有单词:
这将打印出每个排列一次,并且必须包括所有单词:
# 2 楼答案
另一个例子