씨네
공부하는 개발자 강씨네
씨네
  • 분류 전체보기 (460)
    • Web (21)
      • HTML (11)
      • CSS (10)
    • JS 관련 (49)
      • JavaScript (27)
      • JQuery (22)
    • TS 관련 (15)
      • TypeScript (15)
    • NodeJS (7)
      • NodeJS (7)
    • 따라하며 배우는 시리즈 (23)
      • NodeJS & ReactJS Basic (23)
      • NodeJS & ReactJS Movie (0)
      • NodeJS & ReactJS Youtube (0)
      • NodeJS & ReactJS ChatBot (0)
    • SPA (14)
      • React (14)
      • Vue (0)
      • Anguler (0)
    • Java 관련 (118)
      • Java (52)
      • JDBC (6)
      • JSP & Servlet (18)
      • Spring Legecy (38)
      • SpringBoot (4)
    • Python (26)
      • Python (20)
      • PyMongo (1)
      • Django (5)
    • Git (24)
      • Github (24)
    • RDB (22)
      • Oracle (21)
      • MySQL (1)
    • NoSQL (5)
      • MongoDB (5)
    • OS (4)
      • Linux (4)
    • 빅데이터 (2)
      • hadoop (2)
    • IDE (20)
      • eclipse (11)
      • VSCODE (4)
      • VisualStudio (1)
      • IntelliJ (1)
      • PyCharm (1)
      • DBeaver (2)
    • Install (3)
      • Tomcat (1)
      • Docker (1)
      • Anaconda (1)
    • 오류&에러 (28)
      • TS (2)
      • NodeJS (7)
      • SQL (8)
      • Java (1)
      • Spring (4)
      • Git (6)
      • 기타 (0)
    • 알고리즘 (67)
      • 수열 (1)
      • 백준(backjoon) (39)
      • Programmers (27)
    • 자격증 (5)
      • SQLD (5)
    • 기타 (2)
    • IT유튜브로 지식쌓기 (2)

공지사항

인기 글

최근 글

티스토리

250x250
hELLO · Designed By 정상우.
씨네

공부하는 개발자 강씨네

[Programmers]최대공약수와 최소공배수_자바
알고리즘/Programmers

[Programmers]최대공약수와 최소공배수_자바

2021. 8. 4. 11:46
728x90

https://programmers.co.kr/learn/courses/30/lessons/12940?language=java 

 

코딩테스트 연습 - 최대공약수와 최소공배수

두 수를 입력받아 두 수의 최대공약수와 최소공배수를 반환하는 함수, solution을 완성해 보세요. 배열의 맨 앞에 최대공약수, 그다음 최소공배수를 넣어 반환하면 됩니다. 예를 들어 두 수 3, 12의

programmers.co.kr

 

약간은 수학적 사고가 필요한 문제였습니다.

이게 왜 어려울까 싶으면서도 은근 고민을 많이 하게 되는 문제입니다.

 

import java.util.*;

class Solution {
    public int[] solution(int n, int m) {
        int[] answer = new int [2];
        
        if(n > m){
            if(n % m == 0){
                answer[0] = m;
                answer[1] = n;
            }else{
                for(int i = 1; i <= n; i++){
                    if(n % i == 0 && m % i == 0){
                        answer[0] = i;
                    }
                }
                answer[1] = n*m/answer[0];
            }
        }else if(n < m){
            if(m % n == 0){
                answer[0] = n;
                answer[1] = m;
            }else{
                for(int i = 1; i <= m; i++){
                    if(n % i == 0 && m % i == 0){
                        answer[0] = i;
                    }
                }
                answer[1] = n*m/answer[0];
            }
        }
        
        return answer;
    }
}

먼저 n을 m으으로 나누었을때 나머지가 0이라면 더 볼것도 없이 최대공약수와 최소공배수를 알 수 있습니다.

하지만 그렇지 않을경우에는 구하는 공식과 같은 사고가 필요합니다.

728x90

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

[Programmers]소수 찾기_자바 / 프로그래머스 연습문제(level 1)  (0) 2021.08.07
[Programmers]두 개 뽑아서 더하기_자바  (0) 2021.08.05
[Programmers]비밀지도_자바 - 2018 카카오 블라인드  (0) 2021.08.03
[Programmers]실패율_자바  (0) 2021.08.02
[Programmers]멀쩡한 사각형_자바  (0) 2021.08.01
    '알고리즘/Programmers' 카테고리의 다른 글
    • [Programmers]소수 찾기_자바 / 프로그래머스 연습문제(level 1)
    • [Programmers]두 개 뽑아서 더하기_자바
    • [Programmers]비밀지도_자바 - 2018 카카오 블라인드
    • [Programmers]실패율_자바
    씨네
    씨네
    개발자 씨네가 공부하는 내용을 기록 겸 공유하는 블로그입니다!

    티스토리툴바