Written

프로그래머스 레벨2 <타겟 넘버> C++ 풀이 본문

알고리즘 문제풀이

프로그래머스 레벨2 <타겟 넘버> C++ 풀이

steeringhead 2023. 9. 25. 21:00

https://school.programmers.co.kr/learn/courses/30/lessons/43165

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

어렵지 않은 DFS 문제였습니다.

 

주어진 vector의 현재 위치의 값을 더하는경우와 빼는경우를 체크해서 모든 경우를 탐색해보고 마지막 인덱스까지 갔을때, 그 값이 문제에서 주어진 타겟과 같으면 경우의 수를 하나 늘려주면 간단하게 답을 구할 수 있었습니다.

 

 

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
32
33
34
35
36
37
38
39
#include <string>
#include <vector>
 
using namespace std;
 
int last;
int goal;
int answer = 0;
 
void calcul(int val,int curIdx,vector<int>& numbers)
{
    if (curIdx >= last)
    {
        if (val == goal)
        {
            answer++;
            return;
        }            
        else
            return;
    }
    else
    {
        calcul(val+numbers[curIdx+1],curIdx+1,numbers);
        calcul(val-numbers[curIdx+1],curIdx+1,numbers);
    }
}
 
int solution(vector<int> numbers, int target) {
    
    int size = numbers.size();
    last = size-1;
    goal = target;
    
    calcul(0+numbers[0],0,numbers);
    calcul(0-numbers[0],0,numbers);
    
    return answer;
}
cs
Comments