Module: Jumlah awalan


Problem

1 /8


Jumlah pada talian

Theory Click to read/hide

Biar ada beberapa susunan. Sekiranya tiada perubahan, kita boleh dengan cepat (lebih pantas daripada garis) mencari nilai beberapa fungsi pada subsegmen tatasusunan ini. Untuk melakukan ini, kita perlu menggunakan memori tambahan dan melakukan pra-pengiraan.
Sebagai contoh, kita perlu mencari jumlah dengan cepat pada beberapa segmen tatasusunan.
Mari dapatkan tatasusunan jumlah awalan, di mana indeks i akan menjadi jumlah semua elemen tatasusunan dengan indeks kurang daripada atau sama dengan i.
a[] – tatasusunan yang diberikan, p[] – tatasusunan jumlah awalan


Kiraan tatasusunan p:
Jelas sekali p[0] = a[0]. Ambil perhatian bahawa kita boleh mengira semula p[i] dengan mudah melalui p[i – 1], kerana jumlah pada awalan i ialah jumlah pada awalan i – 1 + a[i].
Oleh itu, kod untuk mengira jumlah awalan kelihatan seperti ini:

int a[n], p[n];
p[0] = a[0< /span>];
untuk (int i = 1; i < n; i++)
         p[i] = p[i -  1] + a[i];

Selanjutnya, kami perhatikan bahawa jumlah pada segmen – perbezaan antara dua jumlah pada awalan.


Hijau = merah – biru
Oleh itu, jika perlu mencari jumlah pada selang [l,r], maka jawapannya ialah p[r] – p[l-1].
Walau bagaimanapun, jika l – 1 elemen mungkin tidak wujud. Untuk melakukan tanpa if’s, anda boleh memasukkan pengindeksan 1 dan a[0] dan p[0] akan mempunyai nilai neutral (0 untuk jumlahnya).
 
Ambil perhatian bahawa teknik ini ialah kes khas formula kemasukan-pengecualian, jadi dengan cara ini adalah mungkin untuk menyimpan bukan sahaja jumlah, tetapi juga fungsi lain, seperti pendaraban dan xor.
 

Problem

Diberikan tatasusunan tidak berubah dengan panjang n dan q pertanyaan seperti “kira jumlah subsegmen tatasusunan daripada l hingga r ”. Cetak jawapan untuk setiap permintaan.

Input
Baris pertama mengandungi nombor n – saiz tatasusunan (\(1 <= n <= 10^5\)). Barisan kedua mengandungi n &ndash nombor ; elemen tatasusunan. Nombor modulo tidak melebihi \(10^9\). Baris ketiga mengandungi nombor q – bilangan permintaan (\(1 <= q <= 10^5\)). Diikuti oleh baris q, setiap satu daripadanya mengandungi 2 nombor: l dan r (\(1 <= l <= r <= n\ )).

Output
Cetak jawapan kepada semua pertanyaan, setiap satu pada baris yang berasingan.
 

 

Contoh
# Input Output
1
5
1 2 3 4 5
3
1 2
3 3
2 5
3
3
14