백준 문제 중 2908번, 구현, ‘상수’
백준 문제 중 2908번
https://www.acmicpc.net/problem/2908
문제
상근이의 동생 상수는 수학을 정말 못한다. 상수는 숫자를 읽는데 문제가 있다. 이렇게 수학을 못하는 상수를 위해서 상근이는 수의 크기를 비교하는 문제를 내주었다. 상근이는 세 자리 수 두 개를 칠판에 써주었다. 그 다음에 크기가 큰 수를 말해보라고 했다.
상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.
입력
첫째 줄에 상근이가 칠판에 적은 두 수 A와 B가 주어진다. 두 수는 같지 않은 세 자리 수이며, 0이 포함되어 있지 않다.
출력
첫째 줄에 상수의 대답을 출력한다.
풀이
s = input().split()
# 입력받은 수의 개수와 같은 리스트를 선언
strnum = [None]*len(s)
# 리스트 컴프리헨션을 이용해 대입
strnum = [s[i] for i in range(len(s))]
# 문자열을 뒤집는 함수 선언
def reverse_str(strnums)->str:
temp=''
# strnum 뒤에 temp를 더해 역순으로 temp 재생성
for strnum in strnums:
temp=strnum+temp
return temp
![result](./img/2021-01-02-boj-2908+1.jpg)
#issue1
a = int(reverse_str(strnum[0]))
b = int(reverse_str(strnum[1]))
# max를 이용해 대답
print(max(a,b))
123 456
654
Issue1
위와 같이 코드를 짰고 정답을 맞췄지만 strnum[0]과 같이 하드코딩이 되어 있어서 좀더 유연한 코드를 짜고 싶어졌다.
s = input().split()
# 입력받은 수의 개수와 같은 리스트를 선언
strnum = [None]*len(s)
# 리스트 컴프리헨션을 이용해 대입
strnum = [s[i] for i in range(len(s))]
# 문자열을 뒤집는 함수 선언
# 가변인자를 나타내는 *strnums 활용(패킹)
def reverse_str(*strnums)->str:
temp=''
templist=[]
for strnum in strnums:
for i in strnum:
temp=i+temp
templist.append(temp)
temp=''
return templist
# *strnum을 인자로 넘겨주어 언패킹
answer = max(reverse_str(*strnum))
print(answer)
123 124 125 126 127 128
821
입력해야하는 숫자의 개수가 자유로운 코드가 되었다.
배운점
매개변수의 갯수가 달라질 수 있는 함수 다루는 법
- 패킹과 언패킹 개념과 활용법
- 가변인자, 패킹, 언패킹
Leave a comment