티스토리 뷰

문제 링크

 

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

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

programmers.co.kr

 

 

 

풀이

문제에서 중간에 타겟넘버가 되는 경우가 없고 최종까지 가야 타겟넘버로 지정하는 것이므로 "완전탐색"이다.

재귀로 최종까지 가게되면(index값이 size랑 같을 경우) target이 같은지 여부에 따라 return 1과 0을 나누었다.

 

 

더보기
#include <string>
#include <vector>
#include <queue>
#include <algorithm>

using namespace std;

// +, - 만 하기

// 숫자가 담긴 배열 numbers
// 타겟 넘버 target

int dbfs(vector<int> v, int i, int num, int target){
    if(i == v.size()){      // 최종 계산
        if(num == target) return 1;     // 개수 증가
        else return 0;
    }
    
    int k = i+1;
    return dbfs(v, k, num-v[i], target) + dbfs(v, k, num+v[i], target);
}

int solution(vector<int> numbers, int target) {
    int answer = 0;
    
    answer += dbfs(numbers, 0, 0, target);       // 개수
    
    return answer;      // 타겟 넘버를 만드는 방법의 수를 리턴
}
728x90
반응형
댓글
01-10 15:36
링크