Notice
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 플러터 설치 2022
- android ar 개발
- 안드로이드 레트로핏 crud
- 안드로이드 레트로핏 사용법
- 서비스 vs 쓰레드
- ar vr 차이
- 2022 플러터 설치
- 안드로이드 라이선스
- jvm이란
- android retrofit login
- 자바 다형성
- 안드로이드 os 구조
- 멤버변수
- 안드로이드 라이선스 종류
- 안드로이드 유닛 테스트
- 객체
- rxjava disposable
- 스택 큐 차이
- 서비스 쓰레드 차이
- 안드로이드 유닛테스트란
- jvm 작동 원리
- ANR이란
- 스택 자바 코드
- rxjava cold observable
- rxjava hot observable
- 2022 플러터 안드로이드 스튜디오
- 클래스
- 큐 자바 코드
- Rxjava Observable
- 안드로이드 유닛 테스트 예시
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 홀짝에 따라 다른 값 반환하기 (Kotlin) 본문
728x90
반응형
양의 정수 n이 매개변수로 주어질 때 n이 홀수면 n 이하의 홀수인 모든 양의 정수의 합을 리턴하고, n이 짝수면 n 이하의 짝수인 모든 양의 정수의 제곱의 합을 리턴하는 함수를 작성하라
어떤 숫자를 2로 나눴을 때 1이 남는다면 그 숫자는 홀수고, 1이 남지 않으면 그 숫자는 짝수다.
그리고 어떤 숫자 이하의 홀수 / 짝수는 모두 2를 빼야 얻을 수 있다. 예를 들어 10 이하의 짝수는 8, 6, 4, 2로 10에서 -2를 계속 하다보면 얻을 수 있다. 마찬가지로 7 이하의 홀수는 5, 3, 1로 역시 7에서 -2를 계속 하면 얻을 수 있다. 이제 어떻게 홀짝인 숫자들을 얻을 수 있을지 알았다.
그리고 홀수면 모든 양의 정수의 합을 리턴하고, 짝수면 모든 양의 정수의 합을 제곱해서 리턴해야 한다. 주먹구구식으로 풀면 아래와 같다.
class Solution {
fun solution(n: Int): Int {
var a = 0
for (i in n downTo 1 step 2) {
a += if (n % 2 == 1) {
i
} else {
(i * i)
}
}
return a
}
}
코틀린이 제공하는 키워드인 downTo와 step은 값을 일정 수치만큼 감소시키면서 반복할 때 사용할 수 있는 키워드다.
만약 n이 10이라면 1이 나올 때까지 -2씩 줄어들며 for문이 작동한다. 그래서 8, 6, 4, 2를 각각 제곱해서 더한 다음 리턴한다. 홀수인 경우도 비슷하게 작동한다.
좀 더 간결하게 푼다면 아래와 같다.
class Solution {
fun solution(n: Int): Int = if(n % 2 == 0) {
(n downTo 1 step 2).sumOf { it * it }
} else {
(n downTo 1 step 2).sum()
}
}
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - flag에 따라 다른 값 반환하기 (Kotlin) (0) | 2023.12.03 |
---|---|
[Algorithm] 프로그래머스 - 조건 문자열 (Kotlin) (0) | 2023.12.03 |
[Algorithm] 프로그래머스 - 공배수 (Kotlin) (0) | 2023.12.03 |
[Algorithm] 프로그래머스 - n의 배수 (Kotlin) (0) | 2023.12.03 |
[Algorithm] 프로그래머스 - 두 수의 연산값 비교하기 (Kotlin) (0) | 2023.12.02 |
Comments