Cho mảng a[] có n phần tử. Có q truy vấn, mỗi truy vấn là 2 số L, R. Với mỗi truy vấn, in ra tổng các phần tử từ a[L] đến a[R].
Input Format
Dòng 1 là n và q
Dòng 2 là n số nguyên
q dòng ti...
ADS
0
Trả lời câu hỏi của Lamourahlabontes
Câu trả lời phải chính xác, đầy đủ dựa trên kiến thức xác thực:
✔ Đối với câu hỏi trắc nghiệm: Đưa đáp án lựa chọn + giải thích lý do chọn đáp án.
✔ Đối với câu hỏi tự luận: Đưa lời giải và đáp án cho câu hỏi.
✔ Đối với câu hỏi trả lời ngắn: Đưa ra đáp án + giải thích lý do.
✔ Chấp nhận sử dụng ảnh do thành viên viết tay, ảnh cần rõ nét, không bị mờ, vỡ ảnh.
Sử dụng ngôn ngữ rõ ràng, dễ hiểu.
Tránh đưa ra các ý kiến cá nhân mang tính chất chủ quan.
Nếu sử dụng thông tin từ nguồn khác, phải trích dẫn nguồn đầy đủ và chính xác.
Tuyệt đối không được sao chép các thông tin từ các trang khác, từ AI hoặc chatGPT.
Trợ lý học tập AI - Câu trả lời này chỉ mang tính tham khảo
Dưới đây là đoạn code C++ giải bài toán tổng đoạn (range sum) với n phần tử và q truy vấn, mỗi truy vấn yêu cầu tính tổng từ a[L] đến a[R]. Để xử lý hiệu quả với số lượng lớn n và q (lên đến 10^5), ta sẽ dùng mảng prefix sum để trả lời truy vấn trong O(1) thời gian.
```cpp
#include <iostream>
#include
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int n, q;
cin >> n >> q;
vector<long> a(n + 1, 0);
for (int i = 1; i <= n; i++) {
cin >> a[i];
}
// Tính prefix sum
for (int i = 1; i <= n; i++) {
a[i] += a[i - 1];
}
while (q--) {
int L, R;
cin >> L >> R;
// Tổng đoạn [L, R] = prefix[R] - prefix[L-1]
cout << a[R] - a[L - 1] << "\n";
}
return 0;
}
```
**Giải thích:**
- Đọc vào n, q và mảng a.
- Tạo mảng prefix sum `a` sao cho `a[i]` là tổng các phần tử từ 1 đến i.
- Với mỗi truy vấn (L, R), kết quả là `a[R] - a[L-1]`.
- Đảm bảo dùng kiểu `long long` để tránh tràn số khi tổng lớn.
Bạn có thể chạy thử với input mẫu để kiểm tra. Nếu cần mình có thể giúp bạn thêm.
Hãy giúp mọi người biết câu trả lời này thế nào?
0/5(0 đánh giá)
0
0 bình luận
Bình luận
Nếu bạn muốn hỏi bài tập
Các câu hỏi của bạn luôn được giải đáp dưới 10 phút
FQA.vn Nền tảng kết nối cộng đồng hỗ trợ giải bài tập học sinh trong khối K12. Sản phẩm được phát triển bởi CÔNG TY TNHH CÔNG NGHỆ GIA ĐÌNH (FTECH CO., LTD)
Điện thoại: 1900636019
Email: info@fqa.vn
Địa chỉ: Số 21 Ngõ Giếng, Phố Đông Các, Phường Ô Chợ Dừa, Quận Đống Đa, Thành phố Hà Nội, Việt Nam.