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 플러터 설치
- 안드로이드 라이선스 종류
- 클래스
- jvm이란
- 안드로이드 라이선스
- 안드로이드 유닛 테스트 예시
- jvm 작동 원리
- 서비스 vs 쓰레드
- Rxjava Observable
- 안드로이드 유닛테스트란
- rxjava hot observable
- android retrofit login
- 자바 다형성
- 안드로이드 레트로핏 crud
- 객체
- ar vr 차이
- 스택 자바 코드
- android ar 개발
- 멤버변수
- 안드로이드 레트로핏 사용법
- 2022 플러터 안드로이드 스튜디오
- ANR이란
- 스택 큐 차이
- 안드로이드 유닛 테스트
- 플러터 설치 2022
- rxjava disposable
- 안드로이드 os 구조
- rxjava cold observable
- 서비스 쓰레드 차이
- 큐 자바 코드
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 짝수의 합 (Kotlin) 본문
728x90
반응형
정수 n이 주어질 때, n 이하의 짝수를 모두 더한 값을 리턴하는 solution()을 작성하라
0 초과 1000 이하의 숫자 중 1부터 n까지의 범위에 속하는 모든 짝수들을 더해서 리턴하기만 하면 된다.
주먹구구식으로 푼 코드는 아래와 같다.
class Solution {
fun solution(n: Int): Int {
var a = 0
(1..n).forEach {
if (it % 2 == 0) {
a += it
}
}
return a
}
}
이제 이것을 더 간단하게 만들어본다. 문제를 풀면서 자주 썼던 filter를 사용한다면 이렇게 작성할 수 있다.
class Solution {
fun solution(n: Int) = (0..n).filter { it % 2 == 0 }.sum()
}
filter로 짝수를 검사하기 때문에 intRange를 만들 때 1부터 시작하게 하거나 if를 쓸 필요도 없다.
그리고 filter {}로 걸러낸 값들을 모두 더한 값을 리턴하는 sum()을 쓰기 때문에 프로퍼티를 굳이 선언하지 않아도 되고, 한 줄로 함수 본문을 작성할 수 있게 된다.
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - 외계행성의 나이 (Kotlin) (0) | 2022.12.24 |
---|---|
[Algorithm] 프로그래머스 - 배열 자르기 (Kotlin) (0) | 2022.12.23 |
[Algorithm] 프로그래머스 - 양꼬치 (Kotlin) (0) | 2022.12.23 |
[Algorithm] 프로그래머스 - 각도기 (Kotlin) (0) | 2022.12.23 |
[Algorithm] 프로그래머스 - 문자 반복 출력하기 (Kotlin) (0) | 2022.12.22 |
Comments