差分

#include<bits/stdc++.h>

using i64 = long long;

int main() {

std::ios::sync_with_stdio(false);

std::cin.tie(nullptr);

int n, q;

std::cin >> n >> q;

std::vector<i64> a(n + 1, 0);

std::vector<i64> dif(n + 1, 0);

for (int i = 1; i <= n; i++) {

std::cin >> a[i];

dif[i] = a[i] - a[i - 1];

}

for (int i = 0; i < q; i++) {

i64 l, r, x;

std::cin >> l >> r >> x;

dif[l] += x;

if (r + 1 <= n) {

dif[r + 1] -= x;

}

}

for (int i = 1; i <= n; i++) {

a[i] = a[i - 1] + dif[i];

}

for (int i = 1; i <= n; i++) {

std::cout << a[i] << " \n"[i == n];

}

return 0;

}

全部评论

相关推荐

06-17 21:57
门头沟学院 Java
白友:噗嗤,我发现有些人事就爱发这些,明明已读不回就行了,就是要恶心人
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务