두 스택

문제

승형이와 원빈이는 배낭여행을 가기 위해 두 개의 배낭을 준비했다. 각 배낭에는 N개의 물건이 들어있으며

배낭의 무게는 배낭 안에 남아있는 물건들의 무게의 합으로 정의된다. 원빈이는 최대 K번 두 배낭 중 하나를 선택하여 맨 위에 있는 물건을 없앨 수 있다. 물건을 없애면 선택한 배낭의 무게는 없앤 물건의 무게만큼 줄어들며 선택한 배낭에 물건이 하나도 없으면 아무런 일도 일어나지 않는다.

원빈이의 행동이 모두 끝난 후, 승형이는 자신이 멜 가방을 결정한다. 승형이는 약삭빠르기 때문에 항상 두 배낭 중 더 가벼운 배낭을 메고 다닌다. 만약 두 배낭의 무게가 같다면 둘 중 아무 배낭이나 메고 다닌다. 원빈이가 들어야 하는 배낭은 승형이가 선택하지 않은 배낭이다.

원빈이가 들어야 하는 배낭의 무게의 최솟값을 구해보자.

입력

첫 번째 줄에 두 정수 NK가 주어진다. (1N105,0K2N)

두 번째 줄에 첫 번째 배낭의 물건들의 무게를 나타내는 N개의 정수 A1,A2,,AN이 주어진다. (1Ai109)

세 번째 줄에 두 번째 배낭의 물건들의 무게를 나타내는 N개의 정수 B1,B2,,BN이 주어진다. (1Bi109)

출력

원빈이가 들어야 하는 배낭의 무게의 최솟값을 출력한다.

힌트

이 문제는 입력 데이터의 용량이 커서, 시간 초과를 받지 않으려면 빠른 입출력 방법을 사용해야 할 수 있다.

예제 입력 1 복사

3 2
3 1 4
1 5 9

예제 입력 2 복사

3 0
3 1 4
1 5 9

예제 출력 1 복사

6

예제 출력 2 복사

15