Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 그리디
- 인프콘2024
- Python
- httpCode
- NoSQL
- 코딩문제
- 그래프
- 수학
- 몽고DB
- database
- 데이터
- 파이썬
- 코딩테스트
- 수열
- 백준
- 데이터베이스
- 마크다운문법
- 그리디알고리즘
- 코테
- mongoDB
- db
- 마크다운
- 소수
- Algorithm
- 알고리즘기초
- 기초
- 알고리즘
- chatGPT
- Markdown
- 탐색알고리즘
Archives
- Today
- Total
Dev_from the Bottom
#29. Algorithm20_python) 최소, 최대_백준 10818 본문
문제) 최소, 최대
- 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 방법이 이럴 때 쓰는 건가?
'Algorithm_study' 카테고리의 다른 글
#32. Algorithm22_python) 숫자의 합_백준 11720 (0) | 2022.06.02 |
---|---|
#31. Algorithm21_python) 평균은 넘겠지_백준 4344 (0) | 2022.06.01 |
#26. Algorithm19_python) X보다 작은 수_백준 10871 (0) | 2022.05.30 |
#24. Algorithm18_python) A+B_3_백준 10950 (0) | 2022.05.29 |
#22. Algorithm17_python) 더하기 사이클_백준 1110 (2) | 2022.05.28 |
Comments