当前位置: 首页 > news >正文

CSP-J 2023 复赛第2题:公路 ← 贪心算法

【题目来源】
https://www.luogu.com.cn/problem/P9749
https://www.acwing.com/problem/content/5311/

【题目描述】
小苞准备开着车沿着公路自驾。
公路上一共有 n 个站点,编号为从 1 到 n。
其中站点 i 与站点 i+1 的距离为 vi 公里。
公路上每个站点都可以加油,编号为 i 的站点一升油的价格为 ai 元,且每个站点只出售整数升的油。
小苞想从站点 1 开车到站点 n,一开始小苞在站点 1 且车的油箱是空的。
已知车的油箱足够大,可以装下任意多的油,且每升油可以让车前进 d 公里。
问小苞从站点 1 开到站点 n,至少要花多少钱加油?

【输入格式】
输入的第一行包含两个正整数 n 和 d ,分别表示公路上站点的数量和车每升油可以前进的距离。
输入的第二行包含 n−1 个正整数 v1,v2,…,vn−1,分别表示站点间的距离。
输入的第三行包含 n 个正整数 a1,a2…an,分别表示在不同站点加油的价格。

【输出格式】
输出一行,仅包含一个正整数,表示从站点 1 开到站点 n,小苞至少要花多少钱加油。

【数据范围】
对于所有测试数据保证:1≤n≤10^5,1≤d≤10^5,1≤vi≤10^5,1≤ai≤10^5。

测试点n≤特殊性质
1∼58
6∼1010^3
11∼1310^5A
14∼1610^5B
17∼2010^5

特殊性质 A:站点 1 的油价最低。
特殊性质 B:对于所有 1≤i<n,vi 为 d 的倍数。

【输入样例】
5 4
10 10 10 10
9 8 9 6 5

【输出样例】
79

【样例解释】
最优方案下:小苞在站点 1 买了 3 升油,在站点 2 购买了 5 升油,在站点 4 购买了 2 升油。 

【算法分析】
很明显的贪心问题,如果第 i 站点的油价较 i+1 的贵,i 站的油只要负责到 i+1 站;
否则 i 站的油要多加,直到遇到比他便宜的站。


【算法代码】

#include <bits/stdc++.h>
using namespace std;const int maxn=1e5+5;
long long v[maxn];
long long a[maxn];
long long fc[maxn];int n,d;
long long ans;
long long price;int main() {cin>>n>>d;for(int i=2; i<=n; i++) {cin>>v[i];v[i]+=v[i-1]; //Distance from site i to the starting pointfc[i]=ceil(1.0*v[i]/d); //Fuel consumption from starting point to current site}for(int i=1; i<=n; i++) cin>>a[i];price=a[1];for(int i=2; i<=n; i++) {ans+=price*(fc[i]-fc[i-1]);price=min(price,a[i]);}cout<<ans;return 0;
}/*
in:
5 4
10 10 10 10
9 8 9 6 5out:
79
*/




【参考文献】
https://www.acwing.com/solution/content/206442/
https://mp.weixin.qq.com/s/zckJsihxsDT2JNBFK1ipxA
https://www.acwing.com/solution/content/220349/


 

http://www.lryc.cn/news/303442.html

相关文章:

  • 【LeetCode打卡】Day23|669. 修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.把二叉搜索树转换为累加树
  • Transformer位置表示(Position Encoding)
  • LPDDR6与LPDDR5 State Diagram技术探讨
  • AliLinux的使用Docker初始化服务(详细)
  • docker环境常用容器安装
  • 【论文阅读|基于 YOLO 的红外小目标检测的逆向范例】
  • 【presto权威指南】常用操作
  • Python程序员面试准备:八股文题目与解答思路
  • 如何系统地自学Python?
  • mysql 2-21
  • 【C#】List泛型数据集如何循环移动,最后一位移动到第一位,以此类推
  • LeetCode23.合并K个升序链表
  • (01)Hive的相关概念——架构、数据存储、读写文件机制
  • 二维码扫码登录原理,其实比你想的要简单的多
  • Java 实现 Awaitable(多线程并行等待,类似 AutoEventReset 的作用)
  • AI之Sora:Sora(文本指令生成视频的里程碑模型)的简介(能力/安全性/技术细节)、使用方法、案例应用之详细攻略
  • IListManger feeds流
  • 视频推拉流EasyDSS视频直播点播平台授权出现激活码无效并报错400是什么原因?
  • 设计模式三:工厂模式
  • 2024.2.15 模拟实现 RabbitMQ —— 消息持久化
  • 【技巧】金融企业在搭建服务器时,选择私有云方案还是全栈专属云?
  • 【大厂AI课学习笔记】【2.2机器学习开发任务实例】(10)模型评测
  • 【C++游戏开发-03】贪吃蛇
  • 如何理解CSS的边框宽度?
  • java 写入写出 zip
  • 问题解决:‘telnet‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件
  • 从基础到高级:Linux用户与用户组权限设置详解
  • 【感知机】感知机(perceptron)学习算法知识点汇总
  • 蓝桥杯:C++二分算法
  • Leetcode刷题笔记题解(C++):83. 删除排序链表中的重复元素