티스토리 뷰

📚 문제

입력

  • 첫째 줄에 N이 주어진다. 둘째 줄에는 A에 있는 N개의 수가 순서대로 주어지고, 셋째 줄에는 B에 있는 수가 순서대로 주어진다. N은 50보다 작거나 같은 자연수이고, A와 B의 각 원소는 100보다 작거나 같은 음이 아닌 정수이다.

출력

  • 첫째 줄에 S의 최솟값을 출력한다.

입력 예시 1

5  
1 1 1 6 0  
2 7 8 3 1

출력 예시 1

18

입력 예시 2

3
1 1 3
10 30 20

출력 예시 2

80

입력 예시 3

9
5 15 100 31 39 0 0 3 26
11 12 13 2 3 4 5 9 1

출력 예시 3

528

🧑🏻‍💻 풀이 과정

  • A 배열은 오름차순 정렬, B 배열은 내림차순으로 정렬해서 작은값 * 큰값 순으로 계산하자.
N = int(input())
A = list(map(int, input().split()))
B = list(map(int, input().split()))

A.sort()
B.sort(reverse=True)

time_numbers = []
for i in range(N):
    time_numbers.append(A[i] * B[i])

print(sum(time_numbers))
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
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
글 보관함