[Python] 백준알고리즘 #2163

r1verfuture·2022년 1월 9일
0

백준알고리즘

목록 보기
84/110

📝 문제

정화는 N×M 크기의 초콜릿을 하나 가지고 있다. 초콜릿은 금이 가 있는 모양을 하고 있으며, 그 금에 의해 N×M개의 조각으로 나눠질 수 있다.
초콜릿의 크기가 너무 크다고 생각한 그녀는 초콜릿을 친구들과 나눠 먹기로 했다. 이를 위해서 정화는 초콜릿을 계속 쪼개서 총 N×M개의 조각으로 쪼개려고 한다. 초콜릿을 쪼갤 때에는 초콜릿 조각을 하나 들고, 적당한 위치에서 초콜릿을 쪼갠다. 초콜릿을 쪼갤 때에는 금이 가 있는 위치에서만 쪼갤 수 있다. 이와 같이 초콜릿을 쪼개면 초콜릿은 두 개의 조각으로 나눠지게 된다. 이제 다시 이 중에서 초콜릿 조각을 하나 들고, 쪼개는 과정을 반복하면 된다.
초콜릿을 쪼개다보면 초콜릿이 녹을 수 있기 때문에, 정화는 가급적이면 초콜릿을 쪼개는 횟수를 최소로 하려 한다. 초콜릿의 크기가 주어졌을 때, 이를 1×1 크기의 초콜릿으로 쪼개기 위한 최소 쪼개기 횟수를 구하는 프로그램을 작성하시오.

⌨️ 입력

첫째 줄에 두 정수 N, M(1 ≤ N, M ≤ 300)이 주어진다.

🖨 출력

첫째 줄에 답을 출력한다.

⌨️ 예제 입력 1

2 2

🖨 예제 출력 1

3

⌨️ 예제 입력 2

1 1

🖨 예제 출력 2

0

📚 내가 제출한 코드

import sys
n, m = map(int, sys.stdin.readline().split())
big = max(n, m); small = min(n, m)
print((big - 1) + big * (small - 1))

✏️ 내가 제출한 코드에 대한 설명

  • sys.stdin.readline() : 키보드로 입력한 값을 받는 함수 (기존의 input() 보다 속도가 훨씬 빠르다.)
  • a.split() : a를 빈칸 단위로 쪼개서 반환하는 함수
  • map(a, b) : b의 원소 하나하나를 a에 대입한 것을 반환하는 함수
  • max(a) : a들 중에서 가장 큰 값
  • min(a) : a들 중에서 가장 작은 값
  • 메모리 : 30864 KB
  • 시간 : 76 ms
  • 코드 길이 : 128 B
profile
#iOS #Swift #Developer #Python

0개의 댓글