60008 거울 Gold IV

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

문제

당신은 수직선 위에서 게임을 하고 있다. 당신의 캐릭터는 위치 ss에 있으며, 수직선 위에는 NN개의 거울이 배치되어 있다. 각 거울의 위치는 왼쪽부터 A1A2ANA_1 ≤ A_2 ≤ \cdots ≤ A_N으로 나타낼 수 있다. 한 위치에 여러 개의 거울이 있을 수도 있다.

당신은 거울을 사용해 캐릭터의 위치를 바꿀 수 있다. 이때, 거울을 사용하면 캐릭터의 위치는 거울을 기준으로 점대칭인 지점으로 이동한다. 즉, 당신의 캐릭터가 위치 aa에 있을 때 위치 bb에 있는 거울을 사용하면 당신의 캐릭터는 위치 2ba2b − a로 이동한다.

NN개의 거울은 정확히 한 번씩 사용되어야 한다. 즉, 한 거울을 사용하지 않고 무시할 수는 없으며, 한 거울을 두 번 이상 사용할 수도 없다. 각 거울을 모두 정확히 한 번씩 사용해야 하는 것을 제외하고는, 거울은 당신이 원하는 아무 순서대로 사용할 수 있다.

당신은 이 조건하에서 캐릭터의 위치의 최댓값을 계산하여 출력해야 한다.

입력

첫째 줄에는 거울의 수 NN과 당신의 위치 ss가 공백으로 구분되어 주어진다.

둘째 줄에는 각 거울의 위치 A1,A2,,ANA_1 , A_2 ,\cdots , A_N이 공백으로 구분되어 주어진다.

출력

NN개의 거울을 모두 정확히 한 번씩 사용했을 때 캐릭터의 최종 위치의 최댓값을 출력한다.

답이 커질 수 있으므로 일부 프로그래밍 언어에서는 64비트 정수 변수(long long)를 사용해야 할 수도 있음에 유의하라.

제한

  • 주어지는 모든 수는 정수이다.
  • 1N2000001 ≤ N ≤ 200\, 000
  • 109s109−10^9 ≤ s ≤ 10^9
  • 109A1A2AN109−10^9 ≤ A_1 ≤ A_2 ≤ \cdots ≤ A_N ≤ 10^9

서브태스크

번호배점제한
17N2N ≤ 2.
225NN은 짝수, A1=A2==AN/2<s<AN/2+1=AN/2+2==ANA_1 = A_2 = \cdots = A_{N/2} < s < A_{N/2+1} = A_{N/2+2} = \cdots = A_{N}.
319NN은 짝수, AN/2<s<AN/2+1A_{N/2} < s < A_{N/2+1}.
449추가 제약 조건 없음.

힌트

예제 1 설명

11번 거울을 먼저 이용하고, 그다음에 22번 거울을 이용한다면, 위 그림처럼 캐릭터의 최종 위치는 66이 된다. 반면, 22번 거울을 먼저 이용하고, 그다음에 11번 거울을 이용한다면, 캐릭터의 최종 위치는 6−6이 된다. 고로, 이 예시의 정답은 66이 된다.

예제 입출력

예제 입력 1
2 0
-1 2
예제 출력 1
6
예제 입력 2
6 3
-4 -2 2 6 8 9
예제 출력 2
57
예제 입력 3
9 9
0 1 3 3 4 5 8 9 10
예제 출력 3
49
예제 입력 4
1 1000000000
-999999999
예제 출력 4
-2999999998

출처

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