Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 제로베이스
- 자바스크립트
- 알고리즘
- 코딩테스트 스터디
- 메모리 배리어
- 백트래킹
- map
- Server
- JavaScript
- 구현
- 프론트엔드 스쿨
- C++
- React
- leetcode
- 백준
- 문자열&연산자
- 완전탐색
- 서버
- BFS
- MemoryBarrier
- 코딩테스트
- c#
- N과 M(2)
- 구조체
- Algorithm
- socket
- 멀티스레드
- 프로그래머스
- dfs
- 제로베이스 프론트엔드 스쿨
Archives
- Today
- Total
Written
프로그래머스 레벨2 <타겟 넘버> C++ 풀이 본문
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 |
'알고리즘 문제풀이' 카테고리의 다른 글
프로그래머스 레벨2 <오픈채팅방> C++ 풀이 (0) | 2023.09.28 |
---|---|
프로그래머스 레벨2 <방문 길이> C++ 풀이 (0) | 2023.09.26 |
프로그래머스 레벨2 <튜플> C++ 풀이 (0) | 2023.09.22 |
프로그래머스 레벨2 <수식 최대화> C++ 풀이 (0) | 2023.09.19 |
프로그래머스 레벨2 <삼각 달팽이> C++ 풀이 (1) | 2023.09.19 |
Comments