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 | 31 |
Tags
- 정렬
- 최소스패닝트리
- 알고리즘문제풀이
- 코어자바스크립트
- JS
- 우박수열정적분
- DP
- pccp기출문제
- React.StrictMode
- 타겟넘버
- Lv3
- 5강클로저
- 스택
- c++
- 비트마스크
- 백준 알고리즘
- 백준알고리즘
- 2023카카오블라인드코테
- solved.ac플래티넘
- Lv2
- 프로그래머스
- [pccp 기출문제]
- solved.ac골드
- 두원사이의정수쌍
- 지도 여러개
- 알고리즘 문제풀이
- 이중지도
- JS스터디
- div2개
- 과제진행하기
Archives
- Today
- Total
목록연속 펄스 부분 수열의 합 (1)
호지
[프로그래머스] 연속 펄스 부분 수열의 합 c++
펄스 수열은 두 종류가 있다 [-1, 1, -1...] , [1, -1, 1...] sequence가 주어지면 -1로 시작하는 펄스 수열과 곱해진 s1배열, 1로 시작하는 펄스 수열과 곱해진 s2배열 두가지로 나누어 생각했다. 가장 쉽게 생각할 수 있는 풀이방법은 DFS로 모든 경우의 수를 탐색하는 방법이었다. (하지만 이 방법은 시간 초과이다.) 다음으로 생각해본 방법은 DP이다. 모든 경우의 수를 탐색하면 이미 더했던 부분수열을 다시 더하고 하는 중복과정이 계속 발생한다. 또한 부분수열은 연속해서 이어지는 일렬의 과정이므로 for문 한번으로 해결할 수 있을 것 같았다. 과정은 s1과 s2를 나누어서 계산을 했다. cnt1과 cnt2는 dp배열로, i번째 위치의 의미는 해당 위치에서 나올 수 있는 부분..