2908번: 상수 - Python

beaver.zip·2022년 2월 24일
0

baekjoon

목록 보기
30/56
post-custom-banner

https://www.acmicpc.net/problem/2908

문제

상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.

상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.

두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.

출력

첫째 줄에 상수의 대답을 출력한다.


풀이 1 - 무지성 인덱싱

a, b = input().split()
ar = int(a[2]+a[1]+a[0])
br = int(b[2]+b[1]+b[0])
print(max(ar, br))

문자열을 뒤집는게 핵심인데, 뒤집는 방법을 몰라서 이렇게 풀었다.
간단하고 편한 풀이지만, 만약 문제에서 입력값을 세 자리 수로 제한하지 않았다면 이렇게 풀 수 없었을 것이다.

풀이 2 - [::-1]

a, b = input().split()
ar = int(a[::-1])
br = int(b[::-1])
print(max(ar, br))

이렇게 풀면 입력값의 자리수가 제한되지 않았어도 답을 구할 수 있다.


배울만한 점

[::-1]을 사용하면 문자열을 쉽게 뒤집을 수 있다!

profile
mv blog velog.io/@beaver_zip
post-custom-banner

0개의 댓글