[Bronze II] 스네이크 - 27512
성능 요약
메모리: 108384 KB, 시간: 84 ms
분류
수학, 애드 혹, 사칙연산
제출 일자
2026년 04월 25일 22:04:59
문제 설명
흐즈로는 "스네이크"라는 고전 게임을 매우 좋아합니다. 스네이크는 다음과 같은 규칙에 따라 진행됩니다.
- 게임은 $n \times m$ 격자에서 진행됩니다. 이때, $n$이 $x$축 길이, $m$이 $y$축 길이입니다.
- 플레이어는 격자 위에서 연결된 칸 $c_1, c_2, \dots, c_l$로 구성된 뱀을 상하좌우로 조종합니다. "연결됨"이라고 함은 $1
- 매 턴마다 뱀은 상하좌우 중 한 방향으로 이동합니다. 이 때, 뱀의 마지막 칸 ($c_l$, 이하 "꼬리")이 사라지고, 뱀의 첫 칸 ($c_1$, 이하 "머리")이 조종된 방향으로 한 칸 연장됩니다. 그 후 각 칸의 번호가 새롭게 정해집니다.
- 뱀은 동일한 칸을 동시에 두 번 이상 차지할 수 없습니다. 따라서, 뱀의 머리는 뱀이 지나고 있으면서 꼬리가 위치하지 않은 칸으로는 이동할 수 없습니다.
- 뱀의 머리는 뱀의 두번째 칸 ($c_2$)이 있는 방향으로는 이동할 수 없습니다.
이 게임은 정말 간단하고 유명해서, 최적의 전략도 잘 알려져 있습니다. 바로 머리와 꼬리가 인접한 상태를 유지하면서 이동하는 것입니다! 흐즈로는 이러한 "최적의 전략"을 사용해 얼마나 긴 뱀을 안정적으로 유지할 수 있을지 궁금했습니다. 격자의 가로 길이 $n$과 세로 길이 $m$이 주어질 때, "최적의 전략"을 유지할 수 있는 가장 긴 뱀의 길이를 출력하세요.
입력
두 정수 $n$과 $m$이 한 줄에 공백으로 분리되어 주어집니다. ($2 \le n,m \le 200$)
출력
문제의 정답을 출력하세요.
💡 해결 방법
💻 코드
a, b = map(int, input().split())
if a * b % 2 ==0:
print(a * b)
else:
print(a * b - 1)