[프로그래머스 | 파이썬 / 자바스크립트] 소인수분해(코딩테스트 입문/ level 0)

2023. 2. 24. 15:32·Problem Solving/프로그래머스
반응형
문제

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

 

프로그래머스

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

programmers.co.kr

 

 

🐍파이썬
def solution(n):
    answer = []
    result = []
    i = 2
    while i <= n:
        if n % i == 0:
            n //= i
            answer.append(i)
        else:
            i += 1
    for i in answer:
        if i not in result:
            result.append(i)
    return result

1️⃣ 2 ~ n까지 while문을 돌며 n이 i로 나누어지는 경우 n을 i로 나눈 몫으로 업데이트하고 i를 answer 배열에 저장

2️⃣ n이 더 이상 i로 나누어지는 경우 다음 i를 탐색

3️⃣ 중복 제거

 

🛑 주의

문제에는 <오름차순 정렬>이라는 요구조건이 존재한다.

set()은 원소의 순서를 무시하는 특성이 있기 때문에 set()에 들어간 원소를 리스트로 바꾸어 출력하기 전에 오름차순 정렬이 필요하다.

아래는 set()을 이용한 코드

def solution(n):
    answer = set()
    i = 2
    while i <= n:
        if n % i == 0:
            n //= i
            answer.add(i)
        else:
            i += 1
    return sorted(list(anwer))
더보기

두 코드의 시간 / 공간 복잡도

list 2개 사용 시
set 사용 시

 

 

다른 풀이 방법

def solution(n):
    answer = []
    d = 2
    while d <= n:
        if n % d == 0:
            n /= d
            if d not in answer:
                answer.append(d)
        else:
            d += 1
    return answer

while문 안에서 중복 체크까지 한번에 진행

 

 

 

🐥자바스크립트
function solution(n) {
    var answer = [];
    let i = 2;
    while(i <= n){
        if(n % i == 0){
            n /= i
            if(!answer.includes(i)){
                answer.push(i);
            }            
        } else {
            i++;
        }
    }
    return answer;
}

위 파이썬 <다른 풀이 방법>의 풀이처럼 while문 안에서 중복 체크까지 한번에 진행했다.

 

 

다른 풀이 방법

function solution(n) {
    var answer = [];
    for(let i = 2; i <= n; i++) {
        while (n % i === 0) {
            n = n / i;
            answer.push(i);
        }
    }
    return [...new Set(answer)];
}
반응형
저작자표시 비영리 변경금지 (새창열림)

'Problem Solving > 프로그래머스' 카테고리의 다른 글

[프로그래머스 | 파이썬 / 자바스크립트] 피로도(완전탐색/ level 2)  (0) 2023.02.25
[프로그래머스 | 파이썬 / 자바스크립트] 다항식 더하기(코딩테스트 입문/ level 0)  (0) 2023.02.24
[프로그래머스 | 파이썬 / 자바스크립트] 배열 회전시키기(코딩테스트 입문/ level 0)  (0) 2023.02.24
[프로그래머스 | 파이썬 / 자바스크립트] 문자 반복 출력하기(코딩테스트 입문/ level 0)  (0) 2023.02.23
[프로그래머스 | 파이썬 / 자바스크립트] 삼각형의 완성조건 (1)(코딩테스트 입문/ level 0)  (0) 2023.02.23
[프로그래머스 | 파이썬 / 자바스크립트] 할인 행사(연습문제/ level 2)  (0) 2023.02.23
'Problem Solving/프로그래머스' 카테고리의 다른 글
  • [프로그래머스 | 파이썬 / 자바스크립트] 다항식 더하기(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬 / 자바스크립트] 배열 회전시키기(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬 / 자바스크립트] 문자 반복 출력하기(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬 / 자바스크립트] 삼각형의 완성조건 (1)(코딩테스트 입문/ level 0)
청량리 물냉면
청량리 물냉면
프로그래밍 공부를 하고 있습니다. 공부 내용 정리 겸 정보 공유를 목적으로 합니다.
    반응형
  • 청량리 물냉면
    노력중인 블로그
    청량리 물냉면
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 프로그래밍
        • Programming
        • C | C++
        • Java
        • Python
      • 웹 프로그래밍
        • HTML | CSS
        • JavaScript | TypeScript
        • React
        • Vue.js
        • Next.js
        • Spring & Spring Boot
        • JSP & Servlet
        • DB
      • 웹 프로젝트
        • 웹 프로젝트
        • 🥨스낵몰
        • 👨‍👨‍👧‍👧소셜 가계부
        • 🌜꿈 일기장
        • 🔮포트폴리오 사이트
        • 🏃‍♂️팀 프로젝트: 일정관리 프로그램
        • 📈팀 프로젝트: AI기반 주식 분석 플랫폼
        • 😺Just Meow It: 고양이의 조언
      • 앱 프로그래밍
        • Flutter
        • Kotlin
      • Problem Solving
        • 백준
        • 프로그래머스
        • SWEA
      • Computer Science
        • 알고리즘
        • 컴퓨터 네트워크
        • 이산수학
      • Developer
        • 후기
        • 자료정리
        • 취업 | 취준
        • 웹개발 교육 프로그램
        • TIL
  • 블로그 메뉴

    • 홈
    • Github
  • 공지사항

    • 프로그래밍 공부 중😊
  • 인기 글

  • 태그

    ZeroCho
    웹사이트
    프로젝트
    플러터
    뉴렉처
    spring boot
    구현
    백준
    컴퓨터네트워크
    Jiraynor Programming
    AWS
    블로그 제작
    알고리즘
    SWEA
    강의내용정리
    자바스크립트
    d3
    mysql
    파이썬
    프로그래머스
    공식문서
    bfs
    포트폴리오
    타입스크립트
    리액트
    자바
    React
    Til
    클론 프로젝트
    Next.js
  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
청량리 물냉면
[프로그래머스 | 파이썬 / 자바스크립트] 소인수분해(코딩테스트 입문/ level 0)
상단으로

티스토리툴바