许多对象的排列表示更新如何以不同的顺序出现。但是有时候我们可能在一系列相同的给定对象中有两个对象。在这种情况下,两个序列将相等。在本文中,将看到如何仅表示给定对象列表中的唯一序列。
itertools模块具有一种称为置换的方法,可以帮助我们实现这一目标。为了获得唯一的排列,我们利用set方法的帮助,该方法仅存储不同的元素。但是在此之前,我们使用sorted方法按排序顺序获得了元素。
在下面的程序中,K是我们希望在整个可能的唯一排列中显示的唯一元素的最大数量。使用while循环,我们将唯一元素添加到要显示的最终列表中,仅当它尚未添加到最终列表中时才显示组。
from itertools import permutations def permutation_value(str, k): s = sorted(list(str)) p = permutations(s) m = 0 set_1 = set() str = '' while m < k: str = ''.join(p.__next__()) if str not in set_1: set_1.add(str) print(str) m += 1 str = "xyxxz" i = 12 permutation_value(str, i)
输出结果
运行上面的代码给我们以下结果-
xxxyz xxxzy xxyxz xxyzx xxzxy xxzyx xyxxz xyxzx xyzxx xzxxy xzxyx xzyxx