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
- 통나무 건너기
- DES 알고리즘
- 컬럼 암호화
- 전자 메일
- 욱제는 효도쟁이야!!
- Greedy
- 2 + 1 세일
- 사과 담기 게임
- 구현
- 키워드 암호화
- JoCoding
- 파이썬
- 문자 변환표
- 코딩 테스트
- 세탁소 사장 동혁
- 한빛미디어
- 비연결형 통신
- 위치 암호화
- Pop
- 동적 계획 알고리즘
- 그리디 알고리즘
- 시저 암호화
- 백준
- 소가 길을 건너간 이유3
- 대체 암호화
- ZOAC 2
- 5와 6의 차이
- 거스름돈
- 컴퓨터 네트워크
- 나동빈
Archives
- Today
- Total
주니어로서의 백 걸음, 개발자로서의 한 걸음
[백준 1026] 보물 파이썬 문제 풀이 본문
문제 풀이: S의 최솟값을 구하기 위해서 A배열의 가장 작은 요소와 B배열의 가장 큰 요소를 곱하고 그다음으로 작은 수와 큰 수를 반복해서 곱하고 더해주면 된다. 즉 A배열은 오름차순으로 정렬하고 B배열은 내림차순으로 정렬해서 각각 인덱스끼리 곱해서 더해주면 간단하게 풀 수 있다.
하지만!!
문제에서 B배열은 재배열하면 안 된다고 명시되어있기 때문에 다른 방법을 이용해서 풀어야 한다.
A배열은 재정렬이 가능하기 때문에 A를 오름차순으로 정렬하고 B의 가장 큰 값을 뽑아서 곱해준 더하는 방식으로 문제를 해결하면 된다.
n = int(input())
a_list = list(map(int, input().split()))
b_list = list(map(int, input().split()))
s = 0
for i in range(n):
s += min(a_list) * max(b_list)
a_list.remove(min(a_list))
b_list.remove(max(b_list))
print(s)
리스트에서 del, remove, pop으로 값을 삭제할 수 있다. del과 pop은 삭제하고자 하는 값의 위치(인덱스)를 입력하여 삭제하고 remove는 삭제하고자 하는 데이터를 입력하여 삭제할 수 있다.
#pop을 사용하여 제거하는 경우
for i in range(n):
s += min(a_list) * max(b_list)
a_list.pop(a_list.index(min(a_list)))
b_list.pop(b_list.index(max(b_list)))
print(s)
'Python > 백준 문제풀이' 카테고리의 다른 글
[백준 2217] 로프 파이썬 문제 풀이 (0) | 2023.06.29 |
---|---|
[백준 5585] 거스름돈 파이썬 문제 풀이 (0) | 2023.06.29 |
[백준 11047] 동전 0 파이썬 문제 풀이 (0) | 2023.06.28 |
[백준 11399] ATM 파이썬 문제 풀이 (0) | 2023.06.28 |
백준 10808번 알파벳 개수 (0) | 2023.04.29 |