Dev_from the Bottom

#29. Algorithm20_python) 최소, 최대_백준 10818 본문

Algorithm_study

#29. Algorithm20_python) 최소, 최대_백준 10818

고무라면 2022. 5. 31. 20:16

문제) 최소, 최대

  • N개의 정수가 주어진다. 이때, 최솟값과 최댓값을 구하는 프로그램을 작성하시오.

입력)

  • 첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다.
  • 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다.

출력)

  • 첫째 줄에 주어진 정수 N개의 최솟값과 최댓값을 공백으로 구분해 출력한다.


 


step1) 테스트 : list 고정

list_t = [20, 10, 35, 30, 7]

max_t = list_t[0]
min_t = list_t[0]

for i in list_t:

    # 최솟값
    if i < min_t:
        min_t = i

    # 최대값
    if i > max_t:
        max_t = i

print(min_t, max_t)

>>>

7 35

 

 

step2) 시도1 : n = 5 고정

n = 5
num = list(map(int, input().split()))

min_t = num[0]
max_t = num[0]

for i in num:
    # 최솟값
    if i < min_t:
        min_t = i

    # 최대값
    if i > max_t:
        max_t = i

print(min_t, max_t)

>>>

20 10 35 30 7
7 35

 

 

step3) 최종

n = int(input())
num = list(map(int, input().split()))

min_t = num[0]
max_t = num[0]

for i in num:
    # 최솟값
    if i < min_t:
        min_t = i

    # 최대값
    if i > max_t:
        max_t = i

print(min_t, max_t)

>>>

5
20 10 35 30 7
7 35

 

other solution) min, max 메서드 활용

n = int(input())
num = list(map(int, input().split()))

print(min(num), max(num))

>>>

5
20 10 35 30 7
7 35

# 소회

  • 순수 로직으로 풀기 vs 기존 메서드 이용
  • 이 문제에서는 메모리, 시간 측면에서 그다지 차이가 없음 -> 자원 측면을 어떻게 고려해야 할까
    • BigO 방법이 이럴 때 쓰는 건가?

 

Comments