在Java中生成没有重复排列的变化

在Java中生成没有重复排列的变化,第1张

在Java中生成没有重复/排列的变化

要寻找的关键字是permutation。有大量的源代码
可以免费执行它们。

至于保持无重复,我建议一种简单的递归方法:对于
每个数字,您可以选择是否将其纳入变体,因此您的
递归通过数字进行计数,并分叉为两个递归调用,其中一个
包含数字,其中一个不包括在内。然后,
到达最后一个数字后,每个递归实际上都会为您提供(唯一,排序的)
无重复数字列表。然后,您可以创建
此列表的所有可能排列,并将所有这些排列组合起来以达到最终
结果。

(与duffymo所说的一样:我不会为此提供代码)

高级说明:递归基于0/1(排除,包含),可以
直接转换为位,因此可以转换为整数。因此,为了
获得所有可能的数字组合而不实际执行递归
本身,您可以简单地使用所有10位整数并对其进行迭代
。然后,对数字进行解释,以使设置的位对应
于在列表中包括需要排列的数字。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5643354.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存