atcoder#ABC305D. [ABC305D] Sleep Log

[ABC305D] Sleep Log

配点 : 450450

問題文

高橋くんは睡眠記録をつけています。 睡眠記録は奇数長の数列 A=(A1(=0),A2,,AN)A=(A _ 1(=0), A _ 2,\ldots,A _ N) で表され、奇数番目は起床時刻を、偶数番目は就寝時刻を表しています。 より厳密には、睡眠記録をつけている間に高橋くんは次のような睡眠をとりました。

  • すべての 1iN121\leq i\leq\dfrac{N-1}2 を満たす整数 ii について、睡眠記録をつけ始めてから A2iA _ {2i} 分後ちょうどに寝て、A2i+1A _ {2i+1} 分後ちょうどに起きた。
  • それ以外の時間に寝ることも起きることもなかった。

次の QQ 個の質問に答えてください。 ii 番目の質問では、0liriAN0\leq l _ i\leq r _ i\leq A _ N を満たす整数の組 (li,ri)(l _ i,r _ i) が与えられます。

  • 睡眠記録をつけ始めてから lil _ i 分後ちょうどから rir _ i 分後ちょうどまでの rilir _ i-l _ i 分のうち、高橋くんが寝ていたのは何分間ですか?

制約

  • 3N<2×1053\leq N\lt2\times10^5
  • NN は奇数
  • 0=A1<A2<<AN1090=A _ 1\lt A _ 2\lt\cdots\lt A _ N\leq10^9
  • 1Q2×1051\leq Q\leq2\times10^5
  • 0liriAN (1iQ)0\leq l _ i\leq r _ i\leq A _ N\ (1\leq i\leq Q)
  • 入力はすべて整数

入力

入力は以下の形式で標準入力から与えられる。

NN

A1A _ 1 A2A _ 2 \ldots ANA _ N

QQ

l1l _ 1 r1r _ 1

l2l _ 2 r2r _ 2

\vdots

lQl _ Q rQr _ Q

出力

答えを QQ 行で出力せよ。 ii 行目には ii 番目の質問の答えを整数として出力せよ。

7
0 240 720 1320 1440 1800 2160
3
480 1920
720 1200
0 2160
480
0
960

高橋くんは、以下の図のように睡眠をとりました。

それぞれの質問の答えは以下のようになります。

  • 睡眠記録をつけ始めてから 480480 分後から 19201920 分後の間、高橋くんは 480480 分後から 720720 分後、13201320 分後から 14401440 分後、18001800 分後から 19201920 分後の 33 つの睡眠をとりました。睡眠時間の合計は 240+120+120=480240+120+120=480 分です。
  • 睡眠記録をつけ始めてから 720720 分後から 12001200 分後の間、高橋くんは睡眠をとりませんでした。睡眠時間の合計は 00 分です。
  • 睡眠記録をつけ始めてから 00 分後から 21602160 分後の間、高橋くんは 240240 分後から 720720 分後、13201320 分後から 14401440 分後、18001800 分後から 21602160 分後の 33 つの睡眠をとりました。睡眠時間の合計は 480+120+360=960480+120+360=960 分です。

よって、それぞれの行に 480,0,960480,0,960 と出力してください。

21
0 20 62 192 284 310 323 324 352 374 409 452 486 512 523 594 677 814 838 946 1000
10
77 721
255 541
478 970
369 466
343 541
42 165
16 618
222 592
730 983
338 747
296
150
150
49
89
20
279
183
61
177