我必须生成所有变体,而不能重复数字0-9。
它们的长度可能是1到10。我真的不知道如何解决它, 尤其是如何避免重复。
示例:变化长度:4个随机变化:9856、8753、1243、1234 等(但不是9985-包含重复项)
如果有人可以帮助我解决这个问题,尤其是 提供一些代码和线索,我将非常感激。
要寻找的关键字是permutation。有大量的源代码 可以免费执行它们。
至于保持无重复,我建议一种简单的递归方法:对于 每个数字,您可以选择是否将其纳入变体,因此您的 递归通过数字进行计数,并分叉为两个递归调用,其中一个 包含数字,其中一个不包括在内。然后, 到达最后一个数字后,每个递归实际上都会为您提供(唯一,排序的) 无重复数字列表。然后,您可以创建 此列表的所有可能排列,并将所有这些排列组合起来以达到最终 结果。
(与duffymo所说的一样:我不会为此提供代码)
高级说明:递归基于0/1(排除,包含),可以 直接转换为位,因此可以转换为整数。因此,为了 获得所有可能的数字组合而不实际执行递归 本身,您可以简单地使用所有10位整数并对其进行迭代 。然后,对数字进行解释,以使设置的位对应 于在列表中包括需要排列的数字。