티스토리 뷰

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <vector>
using namespace std;

vector<int> subset;
int n = 4;

void search(int k) {
	if (k == n + 1) {
		// 부분 집합 출력
		for (int i = 0; i < subset.size(); i++)
			cout << subset[i] << " ";
		cout << endl;
	}
	else {
		subset.push_back(k); // k를 부분집합에 포함시킨다.
		search(k + 1);
		subset.pop_back(); // k를 부분집합에 포함시키지 않는다.
		search(k + 1);
	}
}

int main() {
	search(1);
}

 

1부터 n까지의 숫자로 만들 수 있는 부분 집합의 경우의 수를 출력하는 함수다.

마지막 공집합은 빈 줄로 출력이 되기 때문에 실수로 놓치는 것에 주의한다.

 

우리가 부분집합을 손으로 (가지치기하여) 구할 때와 유사한 방식이라고 생각한다.

다만 재귀알고리즘은 익숙하지않으면 코드 자체를 보고 실행결과를 예상하기가 힘들다.


실행 결과:

 

 

댓글
반응형
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함