기몽수
코딩 기록일지
기몽수
전체 방문자
오늘
어제
  • 분류 전체보기 (443)
    • 알고리즘 - SWEA (210)
      • D1 (19)
      • D2 (25)
      • D3 (143)
      • D4 (21)
      • D5 (2)
    • 알고리즘 - Programmers (74)
      • Unrated (34)
      • Lv 0 (4)
      • Lv 1 (3)
      • Lv 2 (32)
      • Lv 3 (1)
    • 알고리즘 - Baekjoon (158)
      • Bronze (1)
      • Silver (65)
      • Gold (90)
      • Platinum (2)
    • 취업 (0)
    • SSAFY (1)
hELLO · Designed By 김용수.
기몽수

코딩 기록일지

알고리즘 - Programmers/Lv 2

[level 2] N개의 최소공배수

2023. 10. 10. 14:42

문제 링크

성능 요약

메모리: 74.2 MB, 시간: 0.04 ms

구분

코딩테스트 연습 > 연습문제

채점결과

정확성: 100.0
합계: 100.0 / 100.0

제출 일자

2023년 10월 2일 14:34:19

문제 설명

두 수의 최소공배수(Least Common Multiple)란 입력된 두 수의 배수 중 공통이 되는 가장 작은 숫자를 의미합니다. 예를 들어 2와 7의 최소공배수는 14가 됩니다. 정의를 확장해서, n개의 수의 최소공배수는 n 개의 수들의 배수 중 공통이 되는 가장 작은 숫자가 됩니다. n개의 숫자를 담은 배열 arr이 입력되었을 때 이 수들의 최소공배수를 반환하는 함수, solution을 완성해 주세요.

제한 사항
  • arr은 길이 1이상, 15이하인 배열입니다.
  • arr의 원소는 100 이하인 자연수입니다.
입출력 예
arr result
[2,6,8,14] 168
[1,2,3] 6

출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges

 

class Solution {
    public int solution(int[] arr) {
        int answer = arr[0];
        for(int i = 1; i < arr.length; i++){
            answer = LCM(answer, arr[i]);
        }
        return answer;
    }
    
    public int GCD(int a, int b){
        while(b != 0){
            int tmp = a % b;
            a = b;
            b = tmp;
        }
        return a;
    }
    
    public int LCM(int a, int b){
        return (a * b) / GCD(a,b);
    }
}

'알고리즘 - Programmers > Lv 2' 카테고리의 다른 글

[level 2] 귤 고르기  (0) 2023.10.11
[level 2] 멀리 뛰기  (1) 2023.10.10
[level 2] 예상 대진표  (1) 2023.10.10
[level 2] [1차] 뉴스 클러스터링  (0) 2023.10.10
[level 2] 튜플  (1) 2023.10.09
    '알고리즘 - Programmers/Lv 2' 카테고리의 다른 글
    • [level 2] 귤 고르기
    • [level 2] 멀리 뛰기
    • [level 2] 예상 대진표
    • [level 2] [1차] 뉴스 클러스터링
    기몽수
    기몽수

    티스토리툴바