У мене є c++ vector
з std::pair<unsigned long, unsigned long>
об'єктами. Я намагаюся генерувати перестановки об'єктів вектора за допомогою std::next_permutation()
. Однак я хочу, щоб перестановки були заданого розміру, як ви знаєте, аналогічно permutations
функції в python, де вказано розмір очікуваної повернутої перестановки.
В основному, c++
еквівалент
import itertools
list = [1,2,3,4,5,6,7]
for permutation in itertools.permutations(list, 3):
print(permutation)
(1, 2, 3)
(1, 2, 4)
(1, 2, 5)
(1, 2, 6)
(1, 2, 7)
(1, 3, 2)
(1, 3, 4)
..
(7, 5, 4)
(7, 5, 6)
(7, 6, 1)
(7, 6, 2)
(7, 6, 3)
(7, 6, 4)
(7, 6, 5)
(1, 1)
? Перестановки python забезпечують дублювання [(1, 1), (1, 1)]
, тоді як std::next_permutation
уникайте дублікатів (лише {1, 1}
).