2019-07-14 13:45:54 +08:00
|
|
|
"""
|
2019-11-16 15:05:00 +08:00
|
|
|
In this problem, we want to determine all possible combinations of k
|
|
|
|
numbers out of 1 ... n. We use backtracking to solve this problem.
|
|
|
|
Time complexity: O(C(n,k)) which is O(n choose k) = O((n!/(k! * (n - k)!)))
|
2019-07-14 13:45:54 +08:00
|
|
|
"""
|
2020-11-30 01:30:31 +08:00
|
|
|
from typing import List
|
2019-07-14 13:45:54 +08:00
|
|
|
|
|
|
|
|
2020-11-30 01:30:31 +08:00
|
|
|
def generate_all_combinations(n: int, k: int) -> List[List[int]]:
|
2019-07-14 13:45:54 +08:00
|
|
|
"""
|
|
|
|
>>> generate_all_combinations(n=4, k=2)
|
|
|
|
[[1, 2], [1, 3], [1, 4], [2, 3], [2, 4], [3, 4]]
|
|
|
|
"""
|
2019-10-05 13:14:13 +08:00
|
|
|
|
2020-11-30 01:30:31 +08:00
|
|
|
result: List[List[int]] = []
|
2019-07-14 13:45:54 +08:00
|
|
|
create_all_state(1, n, k, [], result)
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
2020-11-30 00:19:50 +08:00
|
|
|
def create_all_state(
|
|
|
|
increment: int,
|
|
|
|
total_number: int,
|
|
|
|
level: int,
|
2020-11-30 01:30:31 +08:00
|
|
|
current_list: List[int],
|
|
|
|
total_list: List[List[int]],
|
2020-11-30 00:19:50 +08:00
|
|
|
) -> None:
|
2019-07-14 13:45:54 +08:00
|
|
|
if level == 0:
|
|
|
|
total_list.append(current_list[:])
|
|
|
|
return
|
|
|
|
|
|
|
|
for i in range(increment, total_number - level + 2):
|
|
|
|
current_list.append(i)
|
|
|
|
create_all_state(i + 1, total_number, level - 1, current_list, total_list)
|
|
|
|
current_list.pop()
|
|
|
|
|
|
|
|
|
2020-11-30 01:30:31 +08:00
|
|
|
def print_all_state(total_list: List[List[int]]) -> None:
|
2019-07-14 13:45:54 +08:00
|
|
|
for i in total_list:
|
|
|
|
print(*i)
|
|
|
|
|
|
|
|
|
2019-10-05 13:14:13 +08:00
|
|
|
if __name__ == "__main__":
|
2019-07-14 13:45:54 +08:00
|
|
|
n = 4
|
|
|
|
k = 2
|
|
|
|
total_list = generate_all_combinations(n, k)
|
|
|
|
print_all_state(total_list)
|