CODING TEST/Code Tree

[코드트리 조별과제] 1주차 정리 (최대공약수 구하기/ 최소공배수 구하기/ 출력결과20)

2024. 7. 21. 17:10
목차
  1. 학습내용
  2. 최대공약수 구하기
  3. 최소공배수 구하기
  4. 출력결과 20
728x90

1주차는 시험이 있기도 하고,

오랜만에 코테를 공부하기 때문에

쉬엄쉬엄 가기고 했다.

 

감을 익히고자 기본기인

코드트리의

[프로그래밍 연습] - [함수] - [값을 반환하지 않는 함수]를 풀었다.

 

 

 

 

학습내용

최대공약수 구하기

[코드트리] 최대공약수 구하기

 

 

최대공약수는 공약수와 지수로 구하는 방법이 있다.

 

지수로 구하는 방법은 지수가 있는 형태로 바꾼 뒤 공통된 수 중

지수가 작은 것을 선택해서 곱하는 방법이다.

 

공약수로 구하는 방법은 소인수 분해를 이용한다.

소인수 분해시 큰 수를 사용하면 계산 횟수가 줄어든다.

큰 수를 사용한다는 점을 이용해서

코드를 작성할 수 있다.

 

 

def cal_gcd(n, m): ​​​​for i in range(min(n,m),0,-1): ​​​​​​​​if n % i == 0 and m % i == 0: ​​​​​​​​​​​​return i n, m = map(int, input().split()) print(cal_gcd(n,m))

 

두 수 사이의 최대공약수는

최대 두 수 n, m중 작은 수가 될 수 있다.

 

3과 6의 경우 3이 공통된 약수지만

6은 3의 약수가 아니기 때문에 해당되지 않는다.

 

for i in range(min(n, m),0,-1)를 범위로

설정한다. 큰 수부터 계산하여 연산 횟수를 줄일 수 있다.

 

두 수를 공약수 후보로  나누었을 때

나머지가 공통으로 0으로 떨어질 경우

그 수가 두 수의 최대 공약수다.

 

 

 

 

 

728x90

 

 

 

 


 

 

최소공배수 구하기

[코드트리] 최소공배수 구하기

 

 

 

 

 

 

def lcm(n,m): ​​​​for i in range(max(n, m), (n*m)+1): ​​​​​​​​if i%n==0 and i%m==0: ​​​​​​​​​​​​return i n,m = map(int, input().split()) print(lcm(n,m))

 

두 수중 큰 수는

최소 공배수의 후보가 될 수 있다.

그리고 두 수를 곱하여 나온 결과는

공배수가 된다.

 

이를 이용해

for i in range(max(n, m), (n*m)+1)

범위를 설정한다.

 

공배수 후보를 각 수로 나누었을 때

나머지가 공통으로 0으로 떨어질 경우

그 수가 두 수의 최소 공배수다.

 

 

 

 


 

출력결과 20

[코드트리] 출력결과 20

 

 

이 문제의 경우 손으로 적어보면

쉽게 풀수 있다.

 

 

f함수에 각 값을 넣은 결과는 위의 표와 같다.

 

 

표의 값을 list에 넣으면 위와 같은 단계를 거친다.

 

 

 

result를 계산해보면 0 + 0 + 2 = 2다.

 

 

 

 

 

 

 

 

 

 

728x90

'CODING TEST > Code Tree' 카테고리의 다른 글

[코드트리 조별과제] 3주차 정리(출력결과 18 / 출력결과 29 / 재귀함수를 이용한 최소공배수)  (0) 2024.08.04
[코드트리 조별과제] 2주차 정리 (그 계절, 그 날 / 함수를 이용한 369 게임)  (0) 2024.07.28
[코드트리 챌린지] 8주차 - 마무리와 시작(코드네임, 사는 지역, 비오는 날)  (0) 2023.10.30
[코드트리 챌린지] 7주자 - 계속해서 나아가(용량이 다른 3개의 물통, 십진수와 이진수)  (0) 2023.10.20
[코드트리 챌린지] 6주차 - 다시 시작 ( 이동경로상에 있는 모든 숫자 더하기 / 가운데에서 시작하여 빙빙 돌기 / 007 / Next Level)  (1) 2023.10.17
  1. 학습내용
  2. 최대공약수 구하기
  3. 최소공배수 구하기
  4. 출력결과 20
'CODING TEST/Code Tree' 카테고리의 다른 글
  • [코드트리 조별과제] 3주차 정리(출력결과 18 / 출력결과 29 / 재귀함수를 이용한 최소공배수)
  • [코드트리 조별과제] 2주차 정리 (그 계절, 그 날 / 함수를 이용한 369 게임)
  • [코드트리 챌린지] 8주차 - 마무리와 시작(코드네임, 사는 지역, 비오는 날)
  • [코드트리 챌린지] 7주자 - 계속해서 나아가(용량이 다른 3개의 물통, 십진수와 이진수)
더라
더라
250x250
더라
WINSOME
더라
전체
오늘
어제
  • ALL (63)
    • KNOWLEDGE (4)
      • Software engineering (1)
      • Data base (1)
      • Algorithm (0)
      • Security (2)
    • LANGUAGE (5)
      • Python (3)
      • Java (0)
      • C (0)
      • HTML (0)
      • CSS (2)
      • Javascript (0)
    • CODING TEST (35)
      • Beakjoon (20)
      • Code Tree (15)
    • PROGAMMING (6)
      • AR (0)
      • Android (0)
      • Program (1)
      • Project (5)
    • ERROR (4)
      • Android Error (1)
      • Unity (1)
      • Web (2)
    • Self-improvement (4)
      • certificate (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

최근 댓글

최근 글

hELLO · Designed By 정상우.
더라
[코드트리 조별과제] 1주차 정리 (최대공약수 구하기/ 최소공배수 구하기/ 출력결과20)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.