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
- 스택/큐
- PCCP
- 코딩테스트 연습
- algorighm
- configfile
- frontend
- Stack
- Algorithm
- algorhtim
- Server monitoring
- 점화식
- monorepo
- pnpm
- InfluxDB
- modbus
- javascript
- python
- typescript
- React
- Vite
- 완전탐색
- pymodbus
- Two Pointer
- 알고리즘
- 슬라이딩 윈도우
- 파이썬
- queue
- telegraf
- Jest
- 프로그래머스
Archives
- Today
- Total
DM Log
[연습문제] 연속 부분 수열 합의 개수 - Python / JavaScript 본문
문제 링크 - https://school.programmers.co.kr/learn/courses/30/lessons/131701
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[문제 간단 요약]
1. 원형 수열의 연속 부분의 합으로 만들 수 있는 수의 개수를 구하는 문제
[문제 해결 방안]
1. 1개에서 전체 갯수까지 수열의 합을 구하여 완전 탐색으로 문제 해
[문제 해결 코드 - python]
def solution(elements):
answer_set = set()
change_elements = elements * 2
for i in range(1,len(elements)):
for j in range(len(elements)):
value = sum(change_elements[j:j+i])
answer_set.add(value)
answer_set.add(sum(elements))
return len(answer_set)
- 기존 배열을 2배하여 원형 형식으로 구함 (기존 배열이 크면 클수록 원형 형식의 배열이 커짐)
- 배열의 합을 매번 구하여 성능 저하
[문제 해결 코드 - javascript]
function solution(elements) {
var answer_set = new Set();
for (let i=0; i < elements.length; i++) {
let ssum = 0
for (let j=0; j < elements.length; j++) {
answer_set.add(ssum+=elements[j])
}
elements.push(elements.shift())
}
return answer_set.size;
}
- 수열의 맨 앞의 수를 정하여 문제 해결
- 원형 형식으로 변화는 기존 배열에서 맨 앞의 수를 맨 뒤로 보내어 해결
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[연습문제] 할인 행사 - Python (0) | 2025.03.16 |
---|---|
[월간 코드 챌린지 시즌2] 괄호 회전하기 - Python (0) | 2025.03.11 |
[2017 팁스타운] 예상 대진 - Python / JavaScript (0) | 2025.03.04 |
[ Summer/Winter Coding(~2018)] 영어 끝말잇기 - Python / JavaScript (0) | 2025.03.04 |
[연습문제] N개의 최소공배수 - Python / JavaScript (0) | 2025.02.26 |