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 |
Tags
- 안드로이드 os 구조
- 안드로이드 라이선스
- 클래스
- jvm 작동 원리
- 객체
- Rxjava Observable
- ANR이란
- rxjava cold observable
- 2022 플러터 설치
- 안드로이드 유닛테스트란
- 자바 다형성
- 2022 플러터 안드로이드 스튜디오
- 큐 자바 코드
- 멤버변수
- rxjava hot observable
- 안드로이드 라이선스 종류
- 안드로이드 레트로핏 crud
- 안드로이드 레트로핏 사용법
- 안드로이드 유닛 테스트
- 서비스 vs 쓰레드
- android retrofit login
- android ar 개발
- ar vr 차이
- jvm이란
- 안드로이드 유닛 테스트 예시
- 스택 자바 코드
- 플러터 설치 2022
- rxjava disposable
- 스택 큐 차이
- 서비스 쓰레드 차이
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 합성수 찾기 (Kotlin) 본문
728x90
반응형
약수 개수가 3개 이상인 수를 합성수라고 한다. 자연수 n이 매개변수로 주어질 때, n 이하의
합성수 개수를 리턴하는 solution()을 완성하라
약수를 구하고 약수 개수가 3개 이상인 경우 리턴하는 것까지는 구현했으나 이상하게 자꾸 에러가 발생하면서 몇 개는 맞고 몇 개는 틀렸다고 나왔다.
고민하다가 찾아보니 매개변수가 1이 들어올 수도 있기 때문에 이 경우까지 모두 처리를 해야만 작동했다. 아래는 참고한 자바 풀이 링크와 코틀린으로 바꾼 코드다.
class Solution {
fun div(n: Int): Int {
var count = 0
for (i in 1 .. n) {
if (n % i == 0) count++
}
return count
}
fun solution(n: Int): Int {
var answer = 0
for (i in 1 .. n) {
if (div(i) != 2 && div(i) != 1) {
answer++
}
}
return answer
}
}
정답을 확인하고 다른 풀이를 확인해 보니 역시 간단하게 구현한 코드가 있었다.
class Solution {
fun solution(n: Int) = (1..n).filter { i -> (1..i).filter { i % it == 0 }.size > 2 }.size
}
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - 팩토리얼 (Kotlin) (0) | 2022.12.28 |
---|---|
[Algorithm] 프로그래머스 - 최댓값 만들기(1) (Kotlin) (0) | 2022.12.28 |
[Algorithm] 프로그래머스 - 주사위의 개수 (Kotlin) (0) | 2022.12.28 |
[Algorithm] 프로그래머스 - 배열 회전시키기 (Kotlin) (0) | 2022.12.28 |
[Algorithm] 프로그래머스 - 공 던지기 (Kotlin) (0) | 2022.12.27 |
Comments