海底高铁 前缀和+贪心

有 N N N个城市,每个城市之间有一段铁路,经过两个相邻的城市之间,必须单独购买这一小段的车票,第 i i i段铁路购买纸质单程票需要 A i A_i Ai元,或购买卡,对于第 i i i段铁路,需要花 C i C_i Ci元的工本费购买一张卡,然后乘坐这段铁路一次就只要扣 B i ( B i < A i ) B_i(B_i<A_i) Bi(Bi<Ai)元。现要去 M M M个城市,求最少会花掉多少的钱。

对于每一小段铁路要么全部买纸票,要么全部刷卡。我们需要统计第 i i i段铁路要经过多少次,再比较两者谁便宜。本题数据比较大,需要使用前缀和来统计区间和。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
long long a[100005],b[100005],c[100005],num[100005];
long long ans[100005];
long long sum;
int n,m;
int main()
{
	cin>>n>>m;
	num[0]=0;
	for(int i=1;i<=m;i++)cin>>num[i];
	for(int i=1;i<=n-1;i++)cin>>a[i]>>b[i]>>c[i];
	for(int i=1;i<=m-1;i++)
	{
		int N,M;
		M=max(num[i],num[i+1]);N=min(num[i],num[i+1]);
		ans[N]++;ans[M]--;
	}	
	for(int i=1;i<=n;i++)ans[i]+=ans[i-1];
//	for(int i=1;i<=n;i++)cout<<ans[i]<<" ";
	for(int i=1;i<=n-1;i++)
	sum+=min(a[i]*ans[i],(b[i]*ans[i]+c[i]));
	cout<<sum<<endl;
	cin>>n;
	return 0;
}
相关推荐
weixin_477271697 分钟前
马王堆帛书《周易》六十四貞如何读象(《函谷门》原创)
算法·图搜索算法
汉克老师7 小时前
GESP2024年6月认证C++二级( 第一部分选择题(9-15))
c++·循环结构·分支结构·gesp二级·gesp2级·求余数
追随者永远是胜利者8 小时前
(LeetCode-Hot100)53. 最大子数组和
java·算法·leetcode·职场和发展·go
生成论实验室8 小时前
即事经:一种基于生成论的宇宙、生命与文明新范式
人工智能·科技·神经网络·算法·信息与通信
王老师青少年编程9 小时前
csp信奥赛c++高频考点假期集训(分模块进阶)
数据结构·c++·算法·csp·高频考点·信奥赛·集训
王老师青少年编程9 小时前
2020年信奥赛C++提高组csp-s初赛真题及答案解析(选择题1-5)
c++·题解·真题·初赛·信奥赛·csp-s·提高组
癫狂的兔子10 小时前
【Python】【机器学习】K-MEANS算法
算法·机器学习·kmeans
Bear on Toilet11 小时前
递归_二叉树_50 . 从前序与中序遍历序列构造二叉树
数据结构·算法·leetcode·深度优先·递归
plus4s11 小时前
2月18日(82-84题)
c++·算法·动态规划
wangluoqi11 小时前
c++ 树上问题 小总结
开发语言·c++