일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 앱 출시
- 게시 개요
- Android App 출시
- Firebase
- sql truncate
- android
- 1인개발
- 알고리즘
- double colon
- 코딩테스트
- Groovy lambda
- 그루비 람다
- sql 소수점제거
- 개발일지
- 구글 플레이 스토어 출시
- 예약 배포
- 북마크
- 푸시메세지
- bookmark
- 파이어베이스 크래시틱스
- 이중콜론
- 파이어베이스
- 앱출시
- 예약 게시
- 프로그래머스
- 프로그래머스 수박수박수박수박수박수
- groovy double colon
- Firebase Crashlytics
- mysql 소수점 함수
Archives
- Today
- Total
Moon_Dev_Blog :)
[프로그래머스] 피자 나눠 먹기 (2) 본문
문제 설명 : 머쓱이네 피자가게는 피자를 여섯 조각으로 잘라 줍니다. 피자를 나눠먹을 사람의 수 n이 매개변수로 주어질 때, n명이 주문한 피자를 남기지 않고 모두 같은 수의 피자 조각을 먹어야 한다면 최소 몇 판을 시켜야 하는지를 return 하도록 solution 함수를 완성해보세요.
class Solution {
fun solution(n: Int): Int {
var pizza = 1
while(true) {
if((6 * pizza) % n == 0) return pizza
pizza++
}
return pizza
}
}
// 피자조각: 6
// 나눠 먹을 사람: n
// n: 7
// 6 % 1 ==
풀이방법 : 6조각인 피자를 n(사람)명이 먹고 남지 않을때까지 반복문을 돌면서 피자 판수를 늘려가는 방식이다.
class Solution {
fun solution(n: Int) = lcm(n, 6) / 6
// 5. 30 / 6 => 5
// 최소공배수
fun lcm(n: Int, m: Int) = n * m / gcd(n, m)
// 4. 60(10*6) / 2 => 30
// 최대공약수
// ex 주어진수) 0. 10, 6
fun gcd(n: Int, m: Int): Int {
return if (n < m) {
if (n == 0) m else gcd(n, m % n)
} else {
if (m == 0) n else gcd(m, n % m)
// 1. n: 6, m: 4(10%6)
// 2. n: 4, m: 2(6%4)
// 3. n: 2, m: 0(4%2)
}
}
}
풀이방법 : 고민 해보니.. 최소공배수와, 최대공배수를 활용해서 풀 수 있을거라 생각했고, 유클리드 호제법이라는 공식을 바탕으로 재귀 함수를 사용해서 재풀이를 진행했다
'IT > 알고리즘풀이' 카테고리의 다른 글
[프로그래머스] 문자열 여러 번 뒤집기 (5) | 2024.12.23 |
---|---|
[프로그래머스] Day4 연산, 조건문 (0) | 2024.12.10 |
[프로그래머스] 서울에서 김서방 찾기 / Java (0) | 2021.03.01 |
[프로그래머스] 수박수박수박수박수박수? / Java (0) | 2021.02.26 |
Comments