例如 输入“abc”,打印所有可能出现的组合情况,并且消除重复值。
所谓排列组合如下:
排列组合,字符串:abc
bca
acb
abc
cba
bac
cab
排列组合个数:6
实现代码(结合Java8 lambda表达式实现)
import org.junit.Test; import java.util.ArrayList; import java.util.HashSet; import java.util.List; public class test2 { @Test public void test3() { String input="abc"; //1.开始排列 List<String> sortResult = sort(input); System.out.println("排列组合,字符串:"+input); //2.消除重复列 HashSet h = new HashSet(sortResult); sortResult.clear(); sortResult.addAll(h); //3.打印输出 sortResult.forEach(e -> System.out.println(e)); //4.打印个数 System.out.println("排列组合个数:" + sortResult.size()); } private List<String> sort(String input) { List<String> sortList = new ArrayList(); if (input == null || "".equals(input)) { System.out.println("提示:您输入了空字符,请输入有效值!"); return new ArrayList(); } char leftChar = input.charAt(0); if (input.length() > 1) { String rightString = input.substring(1, input.length()); List<String> rightStringSortedList = sort(rightString); rightStringSortedList.forEach((e) -> { for (int i = 0; i < e.length() + 1; i++) { sortList.add(new StringBuffer(e).insert(i, leftChar).toString()); } }); } else { sortList.add(String.valueOf(leftChar)); } return sortList; } }
如有更简洁的代码实现,请不要吝啬,贴出来分享下。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
问题内容: 我认为我有一个复杂的要求。 它是使用Oracle 10.2的组合排列,我能够使用笛卡尔联接来解决它,但是我认为它需要一些改进以使其更简单,更灵活。 主要行为。 输入字符串 :“一二” 输出 :’一’‘二’‘一二’‘二一’ 对于我的解决方案,我将字符串数限制为5(请注意,输出是阶乘附近的数字) SQL: 问题答案: 编辑:得到了通用的。最终真的很简单(但是花了我一段时间才到达那里) Ed
本文向大家介绍java实现字符串排列组合问题,包括了java实现字符串排列组合问题的使用技巧和注意事项,需要的朋友参考一下 本文为大家介绍了java实现字符串排列组合问题,供大家参考,具体内容如下 组合: 要么选择长度为n的字符串中的第一个字符,那么要在其余的长度n-1的字符串中选择m-1个字符 要么不选择长度为n的字符串中的第一个字符,那么要在其余的长度n-1的字符串中选择m个字符 以上就是本文
问题内容: String database[] = {‘a’, ‘b’, ‘c’}; 我想基于给定生成以下字符串序列。 我只能想到一个漂亮的“虚拟”解决方案。 解决方案非常愚蠢。从某种意义上说,它是不可扩展的 如果我增加的大小怎么办? 如果我最终的目标打印字符串长度必须为N怎么办? 是否有任何智能代码可以以一种非常智能的方式生成可缩放的排列和组合字符串? 问题答案: 您应该检查以下答案:在Java
本文向大家介绍C#查找字符串所有排列组合的方法,包括了C#查找字符串所有排列组合的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了C#查找字符串所有排列组合的方法。分享给大家供大家参考。具体实现方法如下: 希望本文所述对大家的C#程序设计有所帮助。
我正在玩排序数组,我弄清楚了如何对int数组进行合并排序。但是我不知道合并字符串数组。在正常排序时,对字符串数组进行排序很容易,但合并排序不同。我到目前为止所做的代码如下,正在处理int数组。
NowCoder 题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列。例如输入字符串 abc,则打印出由字符 a, b, c 所能排列出来的所有字符串 abc, acb, bac, bca, cab 和 cba。 解题思路 // java private ArrayList ret = new ArrayList<>(); public ArrayList Permutation(