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
- ANR이란
- 안드로이드 레트로핏 crud
- 안드로이드 라이선스 종류
- 안드로이드 유닛 테스트 예시
- android retrofit login
- 플러터 설치 2022
- jvm이란
- 안드로이드 os 구조
- ar vr 차이
- 2022 플러터 설치
- rxjava cold observable
- jvm 작동 원리
- 2022 플러터 안드로이드 스튜디오
- Rxjava Observable
- 안드로이드 레트로핏 사용법
- android ar 개발
- 안드로이드 유닛테스트란
- 안드로이드 유닛 테스트
- rxjava hot observable
- 서비스 vs 쓰레드
- 멤버변수
- 서비스 쓰레드 차이
- 안드로이드 라이선스
- 스택 자바 코드
- rxjava disposable
- 객체
- 클래스
- 스택 큐 차이
- 큐 자바 코드
- 자바 다형성
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 1로 만들기 (Kotlin) 본문
728x90
반응형
앞선 2개 문제들과 마찬가지로 변환 규칙이 있다. 짝수면 반으로 나누고 홀수면 1을 빼고 반으로 나눈다.
이 변환을 반복해서 모든 숫자들이 1이 될 때까지 나누기 연산을 수행한 다음 최종적으로 몇 번 나눴는지를 리턴한다.
class Solution {
fun solution(num_list: IntArray): Int {
var totalDivisions = 0
for (num in num_list) {
var current = num
while (current != 1) {
if (current % 2 == 0) {
current /= 2
} else {
current = (current - 1) / 2
}
totalDivisions++
}
}
return totalDivisions
}
}
1이 되면 계속 변환할 필요가 없기 때문에 while 조건을 current != 1로 주었다. 이렇게 하면 1이 되면 while문이 종료되고 totalDivisions를 리턴하게 되기 때문이다.
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - 원하는 문자열 찾기 (Kotlin) (0) | 2024.05.18 |
---|---|
[Algorithm] 프로그래머스 - 길이에 따른 연산 (Kotlin) (0) | 2024.05.18 |
[Algorithm] 프로그래머스 - 조건에 맞게 수열 변환하기 2 (Kotlin) (0) | 2024.05.18 |
[Algorithm] 프로그래머스 - 조건에 맞게 수열 변환하기 1 (Kotlin) (0) | 2024.05.17 |
[Algorithm] 프로그래머스 - 수열과 구간 쿼리 1 (Kotlin) (0) | 2024.05.16 |
Comments