差分

#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;

}

全部评论

相关推荐

流浪的神仙:无恶意,算法一般好像都得9硕才能干算法太卷啦
点赞 评论 收藏
分享
05-19 19:57
蚌埠学院 Python
2237:Gpa70不算高,建议只写排名,个人技能不在多而在精,缩到8条以内。项目留一个含金量高的,减少间距弄到一页,硕士简历也就一页,本科不要写很多
实习,投递多份简历没人回...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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