18| 差分数组

一、核心思路

采用差分数组的思想,将原数组某个区间上的修改转化为差分数组边界上两点值的修改。反过来再利用用前缀和来还原原数组。

差分数组

还原原数组 ​​

二、代码实现

cpp 复制代码
typedef long long LL;
const int N = 1e6;
int n, q;
LL a[N], f[N];
int main ()
{
	cin >> n >> q;
	// 公式来构造差分数组 
	for (int i = 1; i <= n; i++)
	{
		cin >> a[i];
		f[i] = a[i] - a[i-1]; 
	}
	// 执行操作
	while(q--)
	{
		int l, r, d; cin >> l >> r >> d;
		f[l] += d;
		f[r+1] -= d;
	 } 
	 // 利用前缀和还原原数组
	 for (int i = 1; i <= n; i++)
	 {
	 	a[i] = a[i-1] + f[i];
	 	cout << a[i] << " ";
	  } 
	return 0;
}
cpp 复制代码
typedef long long LL;
const int N = 1e6;
int n, q;
LL f[N];
int main ()
{
	cin >> n >> q;
	// 利用性质来构造差分数组 
	for (int i = 1; i <= n; i++)
	{
		int x; cin >> x;
		f[i] += x;
		f[i+1] -= x; 
	}
	// 执行操作
	while(q--)
	{
		int l, r, d; cin >> l >> r >> d;
		f[l] += d;
		f[r+1] -= d;
	 } 
	 // 利用前缀和还原原数组
	 for (int i = 1; i <= n; i++)
	 {
	 	f[i] = f[i-1] + f[i];
	 	cout << f[i] << " ";
	  } 
	return 0;
}
相关推荐
Robot_Nav20 分钟前
DPMPC-Planner:复杂静态环境与动态障碍物下的无人机实时轨迹规划框架
c++·无人机·mpc
故事和你9127 分钟前
洛谷-数据结构1-4-图的基本应用2
开发语言·数据结构·算法·深度优先·动态规划·图论
是孑然呀37 分钟前
【笔记】激光定位-激光切割指针偏移设置
笔记
吴可可12342 分钟前
C#合并首尾相连多段线实战
算法·c#
光影少年1 小时前
Python+LangGraph学习路线及发展前景
开发语言·人工智能·python·学习
KMDxiaozuanfeng1 小时前
卡梅德生物技术快报|SPR 技术应用|基于 SPR 亲和力的中药活性成分筛选系统实现与数据分析
科技·算法·面试·考试
星辰即远方1 小时前
UI学习3
学习·ui
中屹指纹浏览器2 小时前
2026指纹浏览器性能优化实战:多开稳定性与资源占用控制全解析
经验分享·笔记
水饺编程2 小时前
第5章,[标签 Win32] :获取设备环境的信息
c语言·c++·windows·visual studio
lhbian2 小时前
C++、C与易语言:编程语言对比解析
c语言·开发语言·c++