60019 반품 회수

시간 제한: 1초 메모리 제한: 1024MB

문제

아래 그림과 같이 직선 형태의 도로상에 왼쪽부터 오른쪽으로 11번부터 NN번까지 번호가 붙어 있는 NN개의 집이 있다. ii (1iN1 ≤ i ≤ N)번 집의 위치는 XiX_i (Xi>0X_i > 0)이다.

택배 회사는 한 대의 트럭을 이용해 NN개의 집을 방문하면서 반품되는 물건을 회수하려고 한다. 트럭은 택배 회사가 있는 위치 00에서 시각 00에 출발하고, ii번 집은 시각 TiT_i에 반품할 물건을 내놓는다. 트럭은 11의 속력으로 이동하므로, dd만큼의 거리를 이동하는데 dd시간이 걸린다. 또한, 트럭은 필요하면 움직이지 않고 제자리에 멈춰서 기다릴 수 있다.

트럭은 반품할 물건이 나와있는 집의 위치를 지나면 순식간에 물건을 회수할 수 있다. 즉, 물건을 회수하는 데 소요되는 시간은 00이다. 따라서 트럭은 위치 XiX_i를 시각 TiT_i 또는 그 이후에 지나면 ii번 집에서 내놓은 물건을 회수할 수 있다.

직선 형태의 도로 위에 있는 집의 위치와 반품할 물건을 내놓는 시각이 주어질 때, 트럭이 모든 물건을 회수해서 다시 택배 회사로 돌아오는 데 걸리는 시간의 최솟값을 구하는 프로그램을 작성하라.

입력

첫 번째 줄에 반품할 물건을 내놓을 집의 개수 NN이 주어진다.

두 번째 줄에 각 집의 위치 X1,X2,,XNX_1, X_2, \cdots , X_N이 공백으로 구분되어 주어진다.

세 번째 줄에 각 집이 물건을 내놓는 시각 T1,T2,,TNT_1, T_2, \cdots , T_N이 공백으로 구분되어 주어진다.

출력

첫 번째 줄에 트럭이 모든 물건을 회수하고 다시 택배 회사로 돌아오기 위해 필요한 시간의 최솟값을 출력한다.

제한

  • 주어지는 모든 수는 정수이다.
  • 1N30001 ≤ N ≤ 3\, 000
  • 1X1<X2<<XN1081 ≤ X_1 < X_2 < \cdots < X_N ≤ 10^8
  • 0Ti1080 ≤ T_i ≤ 10^8 (1iN1 ≤ i ≤ N)

서브태스크

110N=2N = 2
215N9N ≤ 9
35모든 1iN1 ≤ i ≤ N에 대해 Ti=0T_i = 0
425모든 2iN2 ≤ i ≤ N에 대해 Ti1TiT_{i-1} ≤ T_i
545추가 제약 조건 없음

예제 입출력

예제 입력 1
4
2 5 7 10
20 4 16 11
예제 출력 1
23
예제 입력 2
3
1 2 3
3 2 1
예제 출력 2
6

출처

올림피아드 한국정보올림피아드 KOI 2024 1차 초등부 3번 고등부 1번
solution.cpp
에디터 불러오는 중...