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
- 서비스 쓰레드 차이
- android ar 개발
- 객체
- jvm이란
- 안드로이드 유닛 테스트
- 클래스
- 안드로이드 os 구조
- 멤버변수
- 자바 다형성
- rxjava disposable
- android retrofit login
- 안드로이드 유닛테스트란
- 2022 플러터 안드로이드 스튜디오
- 서비스 vs 쓰레드
- rxjava hot observable
- 스택 자바 코드
- ar vr 차이
- 2022 플러터 설치
- jvm 작동 원리
- 안드로이드 라이선스 종류
- 안드로이드 유닛 테스트 예시
- Rxjava Observable
- 스택 큐 차이
- ANR이란
- 큐 자바 코드
- 안드로이드 레트로핏 crud
- 안드로이드 라이선스
- rxjava cold observable
- 플러터 설치 2022
- 안드로이드 레트로핏 사용법
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 홀수 vs 짝수 (Kotlin) 본문
728x90
반응형
정수 리스트 num_list가 주어진다. 가장 첫 번째 원소를 1번 원소라고 할 때 홀수 번째 원소들의 합과 원소들의 합 중 큰 값을 리턴하는 함수를 완성하라. 두 값이 같으면 그 값을 리턴한다
매개변수로 받은 num_list 안의 정수들의 홀짝을 구분한 후 종류별로 더해서 갖고 있을 변수를 만들고, num_list 안의 정수를 홀짝으로 나눠서 더한 다음 리턴하도록 짜면 된다. forEachIndexed와 if-else if를 활용하면 간단하게 풀 수 있다.
class Solution {
fun solution(numList: IntArray): Int {
var odd = 0
var even = 0
numList.forEachIndexed { index, i ->
if (index % 2 == 0) {
odd += i
} else {
even += i
}
}
return if (odd > even) {
odd
} else if (odd < even) {
even
} else {
odd
}
}
}
또는 max()를 활용할 수도 있다. 이 경우 filterIndexed 함수를 활용할 수도 있다.
내 컴퓨터 기준으론 첫 번째 풀이가 가장 빠르게 작동했다.
import kotlin.math.*
class Solution {
fun solution(num_list: IntArray): Int {
var answer: Int = 0
return max(
num_list.filterIndexed { i, v -> i % 2 == 0}.sum(),
num_list.filterIndexed { i, v -> i % 2 == 1}.sum()
)
}
}
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - 할 일 목록 (Kotlin) (0) | 2024.05.16 |
---|---|
[Algorithm] 프로그래머스 - 5명씩 (Kotlin) (0) | 2024.05.16 |
[Algorithm] 프로그래머스 - n개 간격의 원소들 (Kotlin) (0) | 2024.04.20 |
[Algorithm] 프로그래머스 - n번째 원소까지 (Kotlin) (0) | 2024.04.20 |
[Algorithm] 프로그래머스 - 왼쪽 오른쪽 (Kotlin) (0) | 2024.04.20 |
Comments