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
- 알고리즘
- DP
- Two Pointer
- 프로그래머스
- typescript
- queue
- InfluxDB
- 파이썬
- React
- 완전탐색
- summerwintercoding
- javascirpt
- 좌표이동
- algorhtim
- 코딩테스트
- Stack
- frontend
- 개발브로그
- modbus
- 42587
- dfs
- Algorithm
- set활용
- javascript
- python
- 스택/큐
- pymodbus
- data platform
- 1844
- configfile
Archives
- Today
- Total
DM Log
[연습문제] 숫자의 표 - Python / JavaScript 본문
문제 링크 - https://school.programmers.co.kr/learn/courses/30/lessons/12924
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[문제 간단 요약]
1. 연속된 숫자의 합이 특정 숫자가 되는 경우의 수를 구하는 문제
[문제 해결 방안] - two pointer
1. 1부터 특정 숫자까지 합을 계산
2. 합이 특정 숫자보다 커질때 맨 처음 더해진 수 빼기
[문제 해결 코드 - python]
def solution(n):
total_count = 0
current_sum = 0
start = 1
for end in range(1, n + 1):
current_sum += end
while current_sum > n:
current_sum -= start
start += 1
if current_sum == n:
total_count += 1
return total_count
[문제 해결 코드 - javascript]
function solution(n) {
let cnt = 1
let ssum = 0
let start = 1
for (i=1; i < n+1; i++) {
if (ssum === n) {
cnt++
}
ssum += i
while (ssum > n) {
ssum -= start++
}
}
return cnt;
}
- 문제에서 JS의 경우 1번 3번 6번 효율성 케이스 시간 초과
- ssum === n 부분을 숫자가 더해지고 나서 바로 확인하고 마지막 맨 마지막 숫자는 개별로 만족한다고 생각하여 cnt는 초기에 1로 시작하니 해결
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[2017 팁스타운] 짝지어 제거하기 - Python / JavaScript (0) | 2025.02.17 |
---|---|
[연습문제] 피보나치 수 - Python / JavaScript (0) | 2025.02.16 |
[월간 코드 첼린지 시즌1] 이진 변환 반복하기 - Python / JavaScript (2) | 2025.02.08 |
[스택/큐] 올바른 괄호 - Python / JavaScript (7) | 2025.02.07 |
[연습문제] JadenCase 문자열 만들기 - Python/JavaScript (2) | 2025.02.03 |