Dev_from the Bottom

#34. Algorithm24_python) 상수_백준 2908 본문

Algorithm_study

#34. Algorithm24_python) 상수_백준 2908

고무라면 2022. 6. 4. 19:57

문제) 상수

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

 

  • 상수는 수를 다른 사람과 다르게 거꾸로 읽는다. 예를 들어, 734와 893을 칠판에 적었다면, 상수는 이 수를 437과 398로 읽는다. 따라서, 상수는 두 수중 큰 수인 437을 큰 수라고 말할 것이다.
  • 두 수가 주어졌을 때, 상수의 대답을 출력하는 프로그램을 작성하시오.

입력)

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

출력)

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

 


 

 

 


step1) 테스트1 : 숫자 뒤집기 로직

n1 = 734

n1_str = str(n1)                   # 뒤집기 위해, 문자열로 전환
n1_str_reverse = n1_str[::-1]      # 뒤집기 : 문자열 슬라이싱 이용 
# n1_str_reverse
n1_reverse = int(n1_str_reverse)   # int로 전환
print(n1_reverse)

>>>
437

 

 

step2) 테스트2 : 숫자 뒤집기 메서드

def reverse(n):
    n_str = str(n)
    n_str_reverse = n_str[::-1]     # 뒤집기
    n_reverse = int(n_str_reverse)
    return n_reverse
    
print(reverse(734))

>>>
437

 

step3) 시도1 : 성공

def reverse(n):
    n_str = str(n)
    n_str_reverse = n_str[::-1]
    n_reverse = int(n_str_reverse)
    return n_reverse

n1, n2 = map(int, input().split())
n1 = reverse(n1)
n2 = reverse(n2)

if n1 > n2:
    print(n1)
else:
    print(n2)
    
>>>
734 893
437

 

 

step4) 시도2 : 메서드 사용하지 않고

  • 어차피 input( )을 통해 입력받은 내용이 '문자열'임을 활용
n1, n2 = input().split()
n1 = int(n1[::-1])  
n2 = int(n2[::-1])

if n1 > n2:
    print(n1)
else :
    print(n2)
    
>>>
734 893
437

 

step5) 최종 : 삼항 연산자

n1, n2 = input().split()
n1 = int(n1[::-1])  
n2 = int(n2[::-1])

print(n1 if n1 > n2 else n2)

>>>
734 893
437

# 배운 점

  • input( ) 메서드에는 '문자열'로 받음!
  • 삼항 연산자 활용

 

# 소회

  • 삼항 연사자가 일반 if문에 비해 훨씬 간결
  • 하지만 막상 결과를 보니, 미묘하지만 시간이 더 걸림
  • 자원 활용 및 코드의 간결성 측면에서 삼항 연산자를 사용하는 것이 좋은가? -> 의문

 

Comments