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 개발
- 클래스
- 안드로이드 라이선스 종류
- Rxjava Observable
- 안드로이드 레트로핏 crud
- jvm 작동 원리
- 안드로이드 레트로핏 사용법
- 스택 큐 차이
- 안드로이드 os 구조
- 안드로이드 유닛 테스트
- ANR이란
- rxjava disposable
- rxjava cold observable
- 자바 다형성
- 2022 플러터 안드로이드 스튜디오
- 객체
- 큐 자바 코드
- 안드로이드 유닛테스트란
- 서비스 쓰레드 차이
- 플러터 설치 2022
- 멤버변수
- ar vr 차이
- rxjava hot observable
- 서비스 vs 쓰레드
- jvm이란
- 안드로이드 유닛 테스트 예시
- android retrofit login
- 2022 플러터 설치
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
