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으로 떨어질 경우
그 수가 두 수의 최대 공약수다.
최소공배수 구하기
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
이 문제의 경우 손으로 적어보면
쉽게 풀수 있다.
f함수에 각 값을 넣은 결과는 위의 표와 같다.
표의 값을 list에 넣으면 위와 같은 단계를 거친다.
result를 계산해보면 0 + 0 + 2 = 2다.
'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 |