蓝桥杯复习之差分

题目:空调

题目链接:https://www.acwing.com/problem/content/description/4265/

思路:

对希望温度与实际温度做差,再对这个做差数组做差分。我们的每次操作等价于在差分数组中选一个数加一或者选两个数一个加一,一个减一。找出差分数组中正数和和负数和中绝对值大的那个就行。

代码:

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

using ll = long long;
const ll N = 100005;
const ll mod = 1e9 + 7;
const int maxn = 2005;
int gcd(int a, int b) {
	return b ? gcd(b, a % b) : a;
}

int p[N];
int t[N];
int fnt[N];
int subs[N];

void solve() {
	int n; cin >> n;
	for (int i = 1; i <= n; i++) {
		cin >> p[i];
	}
	for (int i = 1; i <= n; i++) {
		cin >> t[i];
	}
	for (int i = 1; i <= n; i++) {
		subs[i] = p[i] - t[i];
	}
	for (int i = 1; i <= n; i++) {
		fnt[i] = subs[i] - subs[i - 1];
	}
	int sump = 0, sumn = 0;

	for (int i = 1; i <= n; i++) {
		if (fnt[i] > 0)
			sump += fnt[i];
		else
			sumn += -fnt[i];
	}
	cout << max(sump, sumn) << '\n';
}
		

signed main() {

	ios::sync_with_stdio(false);
	cin.tie(0);
	std::cout.tie(0);

	int t = 1; //cin >> t;
	while (t--)
		solve();

	return 0;
}
相关推荐
珊瑚里的鱼13 分钟前
第九讲 | 模板进阶
开发语言·c++·笔记·visualstudio·学习方法·visual studio
朱剑君14 分钟前
第八天——贪心算法——队列重构问题
算法·贪心算法·重构
仙人掌_lz16 分钟前
深度理解用于多智能体强化学习的单调价值函数分解QMIX算法:基于python从零实现
python·算法·强化学习·rl·价值函数
riri191936 分钟前
算法分析:蛮力法
数据结构·算法
Christo338 分钟前
关于在深度聚类中Representation Collapse现象
人工智能·深度学习·算法·机器学习·数据挖掘·embedding·聚类
摄殓永恒40 分钟前
猫咪几岁
数据结构·c++·算法
机器学习之心1 小时前
分类预测 | Matlab实现ABC-Transformer人工蜂群算法优化编码器多特征分类预测/故障诊断Matlab实现
算法·matlab·分类
oioihoii1 小时前
C++23 新增的查找算法详解:ranges::find_last 系列函数
java·算法·c++23
MoonBit月兔1 小时前
插件双更新:LeetCode 刷题支持正式上线,JetBrains IDE 插件持续升级!
ide·算法·leetcode
.小墨迹1 小时前
Apollo学习——键盘控制速度
linux·开发语言·c++·python·学习·计算机外设