Skip to content

Commit d2d3bf5

Browse files
committed
[level 2] Title: 연속 부분 수열 합의 개수, Time: 2156.26 ms, Memory: 139 MB -BaekjoonHub
1 parent ea64318 commit d2d3bf5

File tree

2 files changed

+103
-0
lines changed

2 files changed

+103
-0
lines changed
Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
# [level 2] 연속 부분 수열 합의 개수 - 131701
2+
3+
[문제 링크](https://school.programmers.co.kr/learn/courses/30/lessons/131701)
4+
5+
### 성능 요약
6+
7+
메모리: 139 MB, 시간: 2156.26 ms
8+
9+
### 구분
10+
11+
코딩테스트 연습 > 연습문제
12+
13+
### 채점결과
14+
15+
정확성: 100.0<br/>합계: 100.0 / 100.0
16+
17+
### 제출 일자
18+
19+
2025년 07월 02일 17:38:59
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>입출력 예 #1<br>
57+
길이가 1인 연속 부분 수열로부터 [1, 4, 7, 9] 네 가지의 합이 나올 수 있습니다.<br>
58+
길이가 2인 연속 부분 수열로부터 [2, 5, 10, 11, 16] 다섯 가지의 합이 나올 수 있습니다.<br>
59+
길이가 3인 연속 부분 수열로부터 [6, 11, 12, 17, 20] 다섯 가지의 합이 나올 수 있습니다.<br>
60+
길이가 4인 연속 부분 수열로부터 [13, 15, 18, 21] 네 가지의 합이 나올 수 있습니다.<br>
61+
길이가 5인 연속 부분 수열로부터 [22] 한 가지의 합이 나올 수 있습니다.<br>
62+
이들 중 중복되는 값을 제외하면 다음과 같은 18가지의 수들을 얻습니다.<br>
63+
[1, 2, 4, 5, 6, 7, 9, 10, 11, 12, 13, 15, 16, 17, 18, 20, 21, 22]</p>
64+
65+
66+
> 출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
import java.util.*;
2+
3+
class Solution {
4+
public int solution(int[] elements) {
5+
Set<Integer> set = new HashSet<>();
6+
7+
8+
// for(int i=1; i<elements.length; i++){ // 0, 1, 2, 3 ... 연속 수열 최대 갯수
9+
// for(int j=0; j<elements.length; j++){
10+
// int sum = 0;
11+
12+
// for(int z=j; z<i; z++){
13+
// sum += elements[(z+i)%elements.length];
14+
// }
15+
// System.out.println(i + " " + sum);
16+
// set.add(sum);
17+
// }
18+
19+
// }
20+
for(int z=1; z<=elements.length; z++){
21+
for(int i=0; i<elements.length; i++){
22+
int sum = 0;
23+
for(int j=0; j<z; j++){ //오프셋
24+
sum += elements[(i+j)%elements.length];
25+
// System.out.println(z + " " + sum);
26+
27+
}
28+
// System.out.println(z + " " + sum);
29+
set.add(sum);
30+
}
31+
}
32+
33+
// set.add()
34+
int answer = set.size();
35+
return answer;
36+
}
37+
}

0 commit comments

Comments
 (0)