본문 바로가기

알고리즘 · 코딩

[백준 14501번] 퇴사

삼성 SW 역량테스트 / 삼성 코딩테스트

 

문제 링크

www.acmicpc.net/problem/14501

 

14501번: 퇴사

첫째 줄에 백준이가 얻을 수 있는 최대 이익을 출력한다.

www.acmicpc.net


C++ 풀이

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

int max_sum;

//DFS로 풀이
void find_max(vector <pair <int, int>>& TP, int currentN, int sum) {
	if (sum > max_sum)
		max_sum = sum;
	for (int i = currentN; i < TP.size(); i++) {
		if (i + TP[i].first <= TP.size())
			find_max(TP, i + TP[i].first, sum + TP[i].second);
	}
	return;
}

int main() {
	max_sum = 0;
	int N;
	cin >> N;
	vector <pair <int, int>> TP(N);
	for (int i = 0; i < N; i++)
		cin >> TP[i].first >> TP[i].second;
	find_max(TP, 0, 0);
	cout << max_sum;
	return 0;
}

DFS로 풀었다.

 

 

반응형