[BOJ / C++] 부분수열의 합 (백트래킹)

2025. 7. 14. 16:14·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/1182

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

void dfs(int depth, int sum, int& cnt, vector<int>& arr, int n, int s) {
	if (depth == n) {
		if (sum == s) {
			cnt++;
		}
		return;
	}

	dfs(depth+1, sum, cnt, arr, n, s);
	dfs(depth+1, sum + arr[depth], cnt, arr, n, s);
}

int main() {
	ios::sync_with_stdio(0); cin.tie(0);

	int n, s;
	cin >> n >> s;
	vector<int> arr;
	for (int i = 0; i < n; i++) {
		int inp;
		cin >> inp;
		arr.push_back(inp);
	}

	int cnt = 0;
	dfs(0, 0, cnt, arr, n, s);

	if (s==0) cnt--;
	cout << cnt;
}

 

2. 분석

DFS 완전탐색 방법을 이용한다. 각 원소가 포함되거나, 포함되지 않거나 하는 경우를 모두 DFS로 탐색하고, depth == n이 되었을 때 sum == s인지 비교해서 골라낸다. 주의할 점은 s가 0일 때 모든 원소가 포함되지 않는 경우를 세게 되는데 해당 케이스에서만 1을 줄여주는 처리를 해주면 된다. Test Case에 s == 0인 경우가 나와있어 해당 부분을 확인할 수 있다.

 

 

3. 시간복잡도

각 깊이 노드에서 재귀 호출을 2번씩 진행하므로 depth가 n인 이진트리모양의 상태공간트리가 된다. 따라서 시간복잡도는 O(2^n)이 된다. 시간제한은 2초이고, n = 20 이하이므로, 2^20 = 1,048,576 (1M) < 10^9 이므로 통과할 수 있다. 

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 재귀함수가 뭔가요? (재귀)  (0) 2025.07.15
[BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)  (0) 2025.07.15
[BOJ / C++] N-Queen (백트래킹)  (0) 2025.07.13
[BOJ / C++] 상범 빌딩 (BFS)  (0) 2025.07.13
[BOJ / C++] 불 (BFS)  (0) 2025.07.13
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 재귀함수가 뭔가요? (재귀)
  • [BOJ / C++] 벽 부수고 이동하기 (BFS로 풀이, 완전탐색 X)
  • [BOJ / C++] N-Queen (백트래킹)
  • [BOJ / C++] 상범 빌딩 (BFS)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (172) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
        • LangChain (0)
      • 코딩테스트 (95) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (12) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] 부분수열의 합 (백트래킹)
상단으로

티스토리툴바