TỔNG ƯỚC SỐ

Nguồn: None

Với mọi số tự nhiên \(m\ (m\ \geq \ 2)\) đều có ít nhất hai ước dương khác nhau đó là 1 và chính nó. Ta kí hiệu \(s(m)\) là tổng của hai ước dương nhỏ nhất (khác nhau) của \(m\).

Ví dụ: \(s(3)\ = \ 1 + 3\ = \ 4;\ s(8)\ = \ 1 + 2\ = \ 3\).

Cho dãy số nguyên dương \(a_{1},\ a_{2},\ \ldots,\ a_{n}\) và cặp chỉ số \(i,\ j\ (1\ \leq \ i\ \leq \ j\ \leq \ n)\).

Yêu cầu: Tính tổng \(s(a_{i})\ + \ s(a_{i} + 1)\ + \ \ldots\ + \ s(a_{j})\).

Dữ liệu vào:

+ Dòng 1 ghi hai số nguyên dương \(n\)\(T\) tương ứng là số số hạng của dãy và số testcase.

+ Dòng 2 ghi \(n\) số nguyên dương \(a_{1},\ a_{2},\ \ldots\ ,\ a_{n}\).

+ T dòng tiếp theo, mỗi dòng là một testcase tương ứng là một cặp chỉ số i, j (1 ≤ ij ≤ n).

Kết quả: gồm T dòng, mỗi dòng là kết quả của testcase tương ứng.

Ví dụ:

Input Output
5 3
2 3 8 9 100
1 3
4 4
3 5
10
4
10

Giới hạn:

+ 30% số test ứng với \(n\ \leq \ 100\)\(T\ \leq \ 10,\ 2\ \leq \ a_{i}\ \leq \ 10^{7}\);

+ 30% số test khác ứng \(n\ \leq \ 100000\), \(T\ \leq \ 1000\)\(2\ \leq \ a_{i}\ \leq \ 10^{4}\);

+ 40% số test còn lại ứng với \(n\ \leq \ 100000,\ T\ \leq \ 10^{4};\ 2\ \leq \ a_{i}\ \leq \ 10^{7}\).

Bạn cần đăng nhập để nộp bài

hpcode.edu.vn
Code tích cực
Trong 24h
  1. qtaydzs1tg (17/23)
  2. ducanhbc (16/23)
  3. duythai (12/18)
Trong 7 ngày
  1. haiyen2011 (69/149)
  2. khanhchi_29 (66/81)
  3. qtaydzs1tg (65/98)
Trong 30 ngày
  1. nongvantien11 (115/189)
  2. trungo0 (112/199)
  3. ngocbichh (110/267)
Thống kê
AC/Sub: 120817/226949
Pascal: 18142
C++: 157988
Python: 50747
Lượt xem/tải tests: 41020

Lưu Hải Phong - 2020
[email protected]