60020 회의 장소

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

문제

KOI 마을에는 NN개의 집이 수직선 위에 지어져 있다. 각 집에는 사람들이 한 명씩 살고 있다. 사람들이 살고 있는 집의 좌표를 작은 순서대로 차례대로 나열했을 때, ii (1iN1 ≤ i ≤ N)번째 집의 좌표는 XiX_i (Xi>0X_i > 0)이다. 마을에 일이 생기면, 마을 사람들은 회의 세트를 통해서 일을 해결한다. 회의 세트는 마을 사람들 전체가 참여할 수도 있고, 일부만 참여할 수도 있다. 회의 세트는 회의들로 구성된다. 회의는 회의 세트의 모든 참여자들이 그중 한 사람의 집에서 모이는 방식으로 진행된다. 회의 세트에서는 모든 참여자들의 집에서 각각 한 번씩 회의를 한다. 즉, 회의 세트에 KK명의 마을 사람들이 참여한다면, 회의 세트에서는 KK번의 회의를 하게 된다. 회의 한 번에 필요한 비용은 회의에 참여하는 각 사람이 자신의 집에서 회의 장소인 집까지 이동하는 거리의 합이다. 회의 세트의 피로도는 각 회의를 할 때 모이는 집의 순서에 따라 달라진다. 회의 세트의 피로도는 모이는 순서에서 인접한 두 집의 회의 비용 차이의 합으로 정의한다.

예를 들어, 좌표 11, 33, 1010, 1111, 1515에 지어진 집에 사람들이 살고 있고, 33, 1010, 1111번 집에 사는 사람들이 회의 세트에 참여한다고 하자. 이때, 좌표가 33인 집에 모이기 위한 비용은 33+310+311=15|3 - 3| + |3 - 10| + |3 - 11| = 15이고, 좌표가 1010인 집에 모이기 위한 비용은 103+1010+1011=8|10 - 3| + |10 - 10| + |10 - 11| = 8, 좌표가 1111인 집에 모이기 위한 비용은 113+1110+1111=9|11 - 3| + |11 - 10| + |11 - 11| = 9이다. 이때, 회의를 위해 모이는 집의 좌표 순서가 310113 - 10 - 11일 경우, 회의 세트의 피로도는 158+89=8|15 - 8| + |8 - 9| = 8이다. 반면, 모이는 집의 좌표 순서가 311103 - 11 - 10일 경우, 피로도는 159+98=7|15 - 9| + |9 - 8| = 7이다. 이 순서로 모일 때, 회의 세트의 피로도가 최소이다.

단, 회의 세트에 참여하는 사람이 11명 이하일 경우, 00이 피로도이다.

KOI 마을에서는 총 QQ번 회의 세트가 열릴 것이다. ii번째 회의 세트는 집의 좌표가 LiL_i이상 RiR_i이하인 집에 사는 사람들이 참여한다. 각 회의 세트의 최소 피로도를 구하는 프로그램을 작성하라.

입력

첫 번째 줄에 NNQQ가 공백으로 구분되어 주어진다.

두 번째 줄에는 마을에 사람이 살고 있는 집들의 좌표 XiX_i가 증가하는 순서대로 주어진다.

다음 QQ개의 줄에, 회의 세트에 대한 정보가 주어진다. ii (1iQ1 ≤ i ≤ Q)번째 줄에는 ii번째 회의 세트에 대한 정보 LiL_iRiR_i가 공백으로 구분되어 주어진다.

출력

QQ개의 줄을 출력한다. ii (1iQ1 ≤ i ≤ Q)번째 줄에는 ii번째 회의 세트의 최소 피로도의 값을 출력한다.

제한

  • 주어지는 모든 수는 정수이다.
  • 1N2000001 ≤ N ≤ 200\, 000
  • 1Q2000001 ≤ Q ≤ 200\, 000
  • 1Xi1091 ≤ X_i ≤ 10^9 (1iN1 ≤ i ≤ N)
  • Xi<Xi+1X_i < X_{i+1} (1i<N1 ≤ i < N)
  • 1LiRi1091 ≤ L_i ≤ R_i ≤ 10^9 (1iQ1 ≤ i ≤ Q)

서브태스크

15N5N ≤ 5, Q5Q ≤ 5
215N16N ≤ 16, Q16Q ≤ 16
315N500N ≤ 500, Q500Q ≤ 500
430N3000N ≤ 3\, 000, Q3000Q ≤ 3\, 000
535추가 제약 조건 없음.

예제 입출력

예제 입력 1
5 1
1 3 10 11 15
3 11
예제 출력 1
7
예제 입력 2
5 5
1 3 11 17 20
1 20
2 2
2 19
2 28
10 16
예제 출력 2
15
0
8
16
0

출처

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