Ý tưởng
Nếu bạn không hiểu, bạn có thể hỏi thêm
Ta gọi pf[i] là tổng các phần tử từ a[1] đến a[i] (để tiện thì ta gọi thêm pf[0] = 0)
Ta thấy, để một dãy a[i...j] (i < j, tính cả a[i] và a[j]) đẹp thì pf[j] - pf[i-1] = k.
Ý tưởng của bài này là với mỗi pf[j], ta tìm xem có bao nhiêu pf[i] với 0 <= i < j sao cho pf[j] - pf[i] = k
Code
#include <bits/stdc++.h>
using namespace std;
int main(){
ios_base::sync_with_stdio(0);cin.tie(0);cout.tie(0);
unordered_map<int,int> mp;
int n,k; cin >> n >> k;
int a[n+1];
int current_sum = 0, ans = 0;
mp[0] = 1; // vi pf[0] = 0
for(int i=1;i<=n;i++) {
cin >> a[i];
current_sum += a[i];
ans += mp[current_sum - k];
mp[current_sum]++;
}
cout << ans;
return 0;
}
Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.
Nguồn : Wikipedia - Bách khoa toàn thưLớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe nhé!
Nguồn : ADMIN :))Xem thêm tại https://loigiaisgk.com/cau-hoi or https://giaibtsgk.com/cau-hoi
Copyright © 2021 HOCTAPSGK