티스토리 뷰
반응형
https://school.programmers.co.kr/learn/courses/30/lessons/120923
프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
문제 설명
연속된 세 개의 정수를 더해 12가 되는 경우는 3, 4, 5입니다. 두 정수 num과 total이 주어집니다. 연속된 수 num개를 더한 값이 total이 될 때, 정수 배열을 오름차순으로 담아 return하도록 solution함수를 완성해보세요.
제한사항
- 1 ≤ num ≤ 100
- 0 ≤ total ≤ 1000
- num개의 연속된 수를 더하여 total이 될 수 없는 테스트 케이스는 없습니다.
풀이
class Solution {
fun solution(num: Int, total: Int): List<Int> {
val answer = mutableListOf<Int>()
var data = total / num
for (i in 0 until num) {
data += if (i % 2 == 0) -i else i
answer.add(data)
}
return answer.sorted()
}
}
AndroidStudio에서 직접 디버깅을 통해 하나하나 찍어보면 이해하기 쉽다.
fun main() {
p120923(4, 14) // BreakPoint
}
fun p120923(num: Int, total: Int): List<Int> {
val answer = mutableListOf<Int>()
var data = total / num
for (i in 0 until num) {
data += if (i % 2 == 0) -i else i
answer.add(data)
}
return answer.sorted()
}
반응형
'Algorithm > programmers_lv0' 카테고리의 다른 글
프로그래머스 lv0 캐릭터의 좌표 (Kotlin) (0) | 2023.05.08 |
---|---|
프로그래머스 lv0 직사각형 넓이 구하기 (Kotlin) (0) | 2023.05.07 |
프로그래머스 lv0 로그인 성공? (Kotlin) (0) | 2023.05.05 |
프로그래머스 lv0 치킨 쿠폰 (Kotlin) (0) | 2023.05.04 |
프로그래머스 lv0 유한소수 판별하기 (Kotlin) (0) | 2023.05.03 |
댓글