Skip to content

Commit 5b32e53

Browse files
committed
[level 2] Title: 연속 부분 수열 합의 개수, Time: 439.77 ms, Memory: 23.2 MB -BaekjoonHub
1 parent 64f765f commit 5b32e53

2 files changed

Lines changed: 102 additions & 0 deletions

File tree

Lines changed: 67 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,67 @@
1+
# [level 2] 연속 부분 수열 합의 개수 - 131701
2+
3+
[문제 링크](https://school.programmers.co.kr/learn/courses/30/lessons/131701)
4+
5+
### 성능 요약
6+
7+
메모리: 23.2 MB, 시간: 439.77 ms
8+
9+
### 구분
10+
11+
코딩테스트 연습 > 연습문제
12+
13+
### 채점결과
14+
15+
정확성: 100.0<br/>합계: 100.0 / 100.0
16+
17+
### 제출 일자
18+
19+
2026년 04월 02일 17:19:10
20+
21+
### 문제 설명
22+
23+
<p>철호는 수열을 가지고 놀기 좋아합니다. 어느 날 철호는 어떤 자연수로 이루어진 원형 수열의 연속하는 부분 수열의 합으로 만들 수 있는 수가 모두 몇 가지인지 알아보고 싶어졌습니다. 원형 수열이란 일반적인 수열에서 처음과 끝이 연결된 형태의 수열을 말합니다. 예를 들어 수열 [7, 9, 1, 1, 4] 로 원형 수열을 만들면 다음과 같습니다.<br>
24+
<img src="https://grepp-programmers.s3.ap-northeast-2.amazonaws.com/files/production/f207cd37-34dc-4cbd-96bb-83435bd6efd4/%EA%B7%B8%EB%A6%BC.png" title="" alt="그림.png"><br>
25+
원형 수열은 처음과 끝이 연결되어 끊기는 부분이 없기 때문에 연속하는 부분 수열도 일반적인 수열보다 많아집니다.<br>
26+
원형 수열의 모든 원소 <code>elements</code>가 순서대로 주어질 때, 원형 수열의 연속 부분 수열 합으로 만들 수 있는 수의 개수를 return 하도록 solution 함수를 완성해주세요.</p>
27+
28+
<hr>
29+
30+
<h5>제한사항</h5>
31+
32+
<ul>
33+
<li>3 ≤ <code>elements</code>의 길이 ≤ 1,000</li>
34+
<li>1 ≤ <code>elements</code>의 원소 ≤ 1,000</li>
35+
</ul>
36+
37+
<hr>
38+
39+
<h5>입출력 예</h5>
40+
<table class="table">
41+
<thead><tr>
42+
<th>elements</th>
43+
<th>result</th>
44+
</tr>
45+
</thead>
46+
<tbody><tr>
47+
<td>[7,9,1,1,4]</td>
48+
<td>18</td>
49+
</tr>
50+
</tbody>
51+
</table>
52+
<hr>
53+
54+
<h5>입출력 예 설명</h5>
55+
56+
<p><br><br>
57+
입출력 예 #1<br>
58+
길이가 1인 연속 부분 수열로부터 [1, 4, 7, 9] 네 가지의 합이 나올 수 있습니다.<br>
59+
길이가 2인 연속 부분 수열로부터 [2, 5, 10, 11, 16] 다섯 가지의 합이 나올 수 있습니다.<br>
60+
길이가 3인 연속 부분 수열로부터 [6, 11, 12, 17, 20] 다섯 가지의 합이 나올 수 있습니다.<br>
61+
길이가 4인 연속 부분 수열로부터 [13, 15, 18, 21] 네 가지의 합이 나올 수 있습니다.<br>
62+
길이가 5인 연속 부분 수열로부터 [22] 한 가지의 합이 나올 수 있습니다.<br>
63+
이들 중 중복되는 값을 제외하면 다음과 같은 18가지의 수들을 얻습니다.<br>
64+
[1, 2, 4, 5, 6, 7, 9, 10, 11, 12, 13, 15, 16, 17, 18, 20, 21, 22]</p>
65+
66+
67+
> 출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges
Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
#include <string>
2+
#include <vector>
3+
#include <set>
4+
5+
using namespace std;
6+
7+
int solution(vector<int> elements) {
8+
int answer = 0;
9+
10+
int length = elements.size();
11+
12+
set<int> s;
13+
14+
for(int i=1; i<=length; i++){
15+
16+
// 시작 지점
17+
for(int j=0; j<length; j++){
18+
int cnt = 0;
19+
int sum = 0;
20+
while(cnt < i){
21+
if(j+cnt < length){
22+
sum += elements[j+cnt++];
23+
}
24+
else{
25+
sum += elements[j+cnt++-length];
26+
}
27+
}
28+
s.insert(sum);
29+
}
30+
}
31+
32+
answer = s.size();
33+
34+
return answer;
35+
}

0 commit comments

Comments
 (0)