[프로그래머스] lv.2 숫자 카드 나누기 python

2023. 4. 9. 19:51·코딩테스트/프로그래머스
반응형

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

 

프로그래머스

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

programmers.co.kr

 

문제 설명

철수가 가진 카드들을 모두 나누면서, 영희가 가진 모든 숫자카드를 나눌 수 없는 숫자

영희가 가진 카드들을 모두 나누면서, 철수가 가진 모든 숫자카드를 나눌 수 없는 숫자

이 두가지 조건 중 하나라도 만족하는 숫자를 골라 return 한다.

만약 없다면 0을 return한다.

 

제한 사항

1 ≤ arrayA의 길이 = arrayB의 길이 ≤ 500,000
1 ≤ arrayA의 원소, arrayB의 원소 ≤ 100,000,000
arrayA와 arrayB에는 중복된 원소가 있을 수 있습니다.

 

문제 풀이

최대공약수를 구해서 문제를 해결했다.

arrayA의 최대공약수 a

arrayB의 최대공약수 b

 

이 두가지를 구해서

arrayA는 b로 나눠서 0이 되는지 확인하고

arrayB는 a로 나눠서 0이 되는지 확인해서

0이 되는경우 cheA나 cheB를 0으로 변경해서 확인한다.

 

만약 둘다 0인 경우 cheA(0)을 return 하고

아니라면 a,b중 큰 값을 return하면 끝!

import math

def solution(arrayA, arrayB):
    answer = 0
    a=arrayA[0]
    b=arrayB[0]

    for i in range(len(arrayA)):
        a=math.gcd(a,arrayA[i])
        b=math.gcd(b,arrayB[i])
        print(a,b)
        
    cheA=1
    cheB=1
    for i in range(len(arrayA)):
        if arrayA[i] % b==0:
            cheA=0
        if arrayB[i] % a==0:
            cheB=0

    if cheA==0 and cheB==0:
        return cheA
    else:
        return max(a,b)
반응형

'코딩테스트 > 프로그래머스' 카테고리의 다른 글

[프로그래머스] lv.1 공원산책 python  (0) 2023.04.17
[프로그래머스] lv.1 신고 결과 받기 python  (1) 2023.04.16
[프로그래머스] lv.1 기사단원의 무기 python  (0) 2023.04.09
[프로그래머스] lv.2 숫자 변환하기 python  (0) 2023.04.09
[프로그래머스] lv.2 테이블 해시 함수 python  (0) 2023.04.09
'코딩테스트/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] lv.1 공원산책 python
  • [프로그래머스] lv.1 신고 결과 받기 python
  • [프로그래머스] lv.1 기사단원의 무기 python
  • [프로그래머스] lv.2 숫자 변환하기 python
시시응
시시응
시시응 블로그
  • 시시응
    시시응응
    시시응
  • 전체
    오늘
    어제
    • 분류 전체보기 (126)
      • KT AIVLE (31)
      • 대외활동 (32)
        • 사회리더 대학생 멘토링 (0)
        • 22 하반기 코드클럽 (7)
        • 23 상반기 코드클럽 (9)
        • 1784 스쿨혁명 (15)
        • 멋쟁이 사자처럼 (1)
      • 프로젝트 (8)
        • 캡스톤 (3)
        • SnapNote (5)
      • study (1)
        • 데이터분석 (1)
      • 코딩테스트 (49)
        • 프로그래머스 (31)
        • 백준 (15)
        • 알고리즘 (2)
        • 자료구조 (1)
      • IT (5)
        • Git (3)
        • 개발환경 (2)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    KT
    대외활동
    Lv1
    Python
    네이버커넥트재단
    교육봉사
    프로그래머스
    코드클럽
    코딩테스트
    1784스쿨혁명
    코테
    파이썬
    AIVLE
    대학생
    에이블스쿨
    소프트웨어야놀자
    playsw_mentor
    코드클럽한국위원회
    KT에이블스쿨
    codeclub_south_korea
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.1
시시응
[프로그래머스] lv.2 숫자 카드 나누기 python
상단으로

티스토리툴바