海底高铁 前缀和+贪心

有 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;
}
相关推荐
akarinnnn3 分钟前
【DAY15】:深⼊理解指针(6)
算法
Lauren_Blueblue7 分钟前
第十六届蓝桥杯省赛Python研究生组-C变换数组
python·算法·蓝桥杯·编程基础
梓䈑8 分钟前
Gflags解剖课:从DEFINE宏到命令行解析的工程化实践
c++·gflags
Tanecious.19 分钟前
蓝桥杯备赛:Day8-小红杀怪
c++·蓝桥杯
wregjru34 分钟前
【高并发服务器项目】2.服务器业务层设计详解
c++
生信研究猿43 分钟前
leetcode 101.对称二叉树(不会做)
算法·leetcode·职场和发展
重生之我是Java开发战士44 分钟前
【笔试强训】Week1:点击消除,数组中两个字符串的最小距离,dd爱框框,腐烂的苹果,大数乘法
java·开发语言·算法
枫叶林FYL44 分钟前
【自然语言处理 NLP】前沿架构与多模态 选择性状态空间模型与并行扫描算法:从原理到实现
算法·自然语言处理·架构
牧瀬クリスだ1 小时前
优先级队列——堆
java·开发语言·数据结构
WolfGang0073211 小时前
代码随想录算法训练营 Day29 | 动态规划 part02
算法·动态规划