프로그래머스, 자바스크립트) 유한소수 판별하기

2024. 3. 15. 02:08·개발/알고리즘(코딩테스트)

문제

https://school.programmers.co.kr/learn/courses/30/lessons/120878

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

풀이

여러가지 꼼수를 부려보다가 실패해서 결국 정석대로...

일단 기약분수를 한번에 만들어 주기 위해서는 분자, 분모의 최대공약수를 구하면 된다.

최대공약수를 구한다음 분모를 기약분수로 만들준다 num = b/gcd

 

기약분수의 분모인 num이 2또는 5만 소인수로 가지고 있어야 되므로

2와 5로 계속 나누어 1이 되는지 확인해준다

 

예시로 10이 기약분수라면 2로 계속 나눴을때 5

5를 계속 나누었을땐 1 이 나오므로 유한소수인걸 확인할 수 있다.

function solution(a, b) {
  //기약분수 만들어주기,최소공약수로 나누기
  const gcd = (a, b) => (a % b === 0 ? b : gcd(b, a % b));
  let num = b / gcd(a, b);

  // 분모의 소인수가 2와 5만을 포함하는지 확인
  while (num % 2 === 0) {
    num /= 2;
  }
  while (num % 5 === 0) {
    num /= 5;
  }

  // 소수가 남아있지 않으면 유한소수
  return num === 1 ? 1 : 2;
}
저작자표시 비영리 변경금지 (새창열림)

'개발 > 알고리즘(코딩테스트)' 카테고리의 다른 글

프로그래머스, 자바스크립트) 특이한 정렬  (0) 2024.03.18
프로그래머스, 자바스크립트) 배열 만들기 2  (0) 2024.03.17
프로그래머스, 자바스크립트) 문자열 밀기  (0) 2024.03.14
프로그래머스, 자바스크립트) 저주의 숫자 3  (3) 2024.03.12
프로그래머스, 자바스크립트) 치킨 쿠폰  (0) 2024.03.09
'개발/알고리즘(코딩테스트)' 카테고리의 다른 글
  • 프로그래머스, 자바스크립트) 특이한 정렬
  • 프로그래머스, 자바스크립트) 배열 만들기 2
  • 프로그래머스, 자바스크립트) 문자열 밀기
  • 프로그래머스, 자바스크립트) 저주의 숫자 3
빔네모
빔네모
console.log("빔네모")
  • 빔네모
    bimnemo("개발")
    빔네모
  • 전체
    오늘
    어제
    • 기록 (143) N
      • 기술 (36) N
        • JavaScript (1)
        • TypeScript (9)
        • React.js (10)
        • Next.js (0)
        • 라이브러리,도구 (3)
        • HTML,CSS (4) N
        • CS (5)
        • BE (4)
      • 개발 (95)
        • 프로젝트 (0)
        • 트러블슈팅 (5)
        • 알고리즘(코딩테스트) (90)
      • 정보 (4)
      • 취미 (8)
        • 감상 (8)
  • 인기 글

  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
빔네모
프로그래머스, 자바스크립트) 유한소수 판별하기
상단으로

티스토리툴바