프로그래머스 문제풀이/LEVEL 2

[프로그래머스 / Level 2] 타겟 넘버

지나가던 개발자 2021. 11. 1. 23:36
반응형

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

 

코딩테스트 연습 - 타겟 넘버

n개의 음이 아닌 정수가 있습니다. 이 수를 적절히 더하거나 빼서 타겟 넘버를 만들려고 합니다. 예를 들어 [1, 1, 1, 1, 1]로 숫자 3을 만들려면 다음 다섯 방법을 쓸 수 있습니다. -1+1+1+1+1 = 3 +1-1+1+1+

programmers.co.kr

numbers의 길이가 20개 이하라는 점과 가능한 연산의 수가 +, - 두 가지라는 점을 먼저 생각해야 합니다.

이것은 모든 케이스에 대해서 계산해도 2의 20승인 1,048,576이므로 시간초과가 발생하지 않는 것을 알 수 있습니다.

 

문제 접근법

  • number 배열에 있는 값들을 재귀함수를 이용하여 모든 계산할 수 있는 케이스에 대해서 시행해본다.
  • 진행한 횟수가 nubers의 길이만큼이라면 계산한 값이 target과 일치하는지 확인한다
    • 일치할 경우 answer을 증가시킨다.
    • 아닐 경우 함수를 종료시킨다.

 

아래는 코드입니다.

더보기
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
#include <string>
#include <vector>
 
using namespace std;
 
int answer = 0;
int t;
vector<int> num;
 
void Calculate(int sum, int index, int nLen)
{
    if (index == nLen)
    {
        if (sum == t)
            answer++;
        
        return;
    }
    
    Calculate(sum + num[index], index + 1, nLen);
    Calculate(sum - num[index], index + 1, nLen);
}
 
int solution(vector<int> numbers, int target) {
    int len = numbers.size();
    t = target;
    num = numbers;
    
    Calculate(00, len);
    
    return answer;
}
cs

 

반응형