news 2026/6/24 22:29:48

算法竞赛备考冲刺必刷题(C++) | 洛谷 P10934 西瓜种植

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法竞赛备考冲刺必刷题(C++) | 洛谷 P10934 西瓜种植

本文分享的必刷题目是从蓝桥云课洛谷AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。

欢迎大家订阅我的专栏:算法题解:C++与Python实现!

附上汇总贴:算法竞赛备考冲刺必刷题(C++) | 汇总


【题目来源】

洛谷:P10934 西瓜种植 - 洛谷

【题目描述】

笨笨种了一块西瓜地,但这块西瓜地的种植范围是一条直线的……

笨笨在一番研究过后,得出了m mm个结论,这m mm个结论可以使他收获的西瓜最多。

笨笨的结论是这样的:

从西瓜地b bb处到e ee处至少要种植t tt个西瓜,这个范围的收获就可以最大化。

笨笨不想那么辛苦,所以他想种植的西瓜尽量少,而又满足每一个所得的结论。

【输入】

第一行两个数n nn,m mm0 < n ≤ 5000 0<n \le 50000<n50000 ≤ m ≤ 3000 0 \le m\le 30000m3000),表示笨笨的西瓜地长n nn,笨笨得出m mm个结论。

接下来m mm行表示笨笨的m mm个结论,每行三个数b bb,e ee,t tt1 ≤ b ≤ e ≤ n 1 \le b\le e\le n1ben0 ≤ t ≤ e − b + 1 0 \le t\le e-b+10teb+1)。

【输出】

输出笨笨最少需种植多少西瓜。

【输入样例】

9 4 1 4 2 4 6 2 8 9 2 3 5 2

【输出样例】

5

【算法标签】

《洛谷 P10934 西瓜种植》 #贪心# #差分约束#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=5005,M=N*3;// 最大顶点数和边数inth[N],e[M],w[M],ne[M],idx;// 链式前向星存储图intdist[N];// 最长距离数组boolst[N];// 标记顶点是否在队列中intn,m;// n: 范围[0,n], m: 区间约束数量/** * 添加有向边 * @param a 起点 * @param b 终点 * @param c 权重 */voidadd(inta,intb,intc){e[idx]=b;// 边指向的顶点w[idx]=c;// 边的权重ne[idx]=h[a];// 指向原链表头h[a]=idx++;// 更新头指针}/** * SPFA算法求最长路径 * 从顶点0开始,计算到所有顶点的最长路径 */voidspfa(){// 初始化距离为负无穷memset(dist,-0x3f,sizeof(dist));memset(st,0,sizeof(st));queue<int>q;// SPFA队列q.push(0);// 起点入队st[0]=true;// 标记在队列中dist[0]=0;// 起点距离为0while(!q.empty()){intt=q.front();// 取出队首q.pop();st[t]=false;// 标记不在队列中// 遍历t的所有邻接边for(inti=h[t];i!=-1;i=ne[i]){intj=e[i];// 邻接顶点// 松弛操作:求最长路径if(dist[j]<dist[t]+w[i]){dist[j]=dist[t]+w[i];// 更新最长距离// 如果j不在队列中,入队if(!st[j]){q.push(j);st[j]=true;}}}}}intmain(){// 输入n和区间约束数量mcin>>n>>m;// 初始化邻接表memset(h,-1,sizeof(h));// 添加基础约束边// 顶点编号0~n,共n+1个顶点for(inti=1;i<=n;i++){// 约束1: S_i - S_{i-1} ≤ 1// 即: S_{i-1} - S_i ≥ -1// 建边: i → i-1,权重-1add(i,i-1,-1);// 约束2: S_i ≥ S_{i-1}// 即: S_i - S_{i-1} ≥ 0// 建边: i-1 → i,权重0add(i-1,i,0);}// 添加区间约束while(m--){intb,e,t;cin>>b>>e>>t;// 约束: S_e - S_{b-1} ≥ t// 即: S_e ≥ S_{b-1} + t// 建边: b-1 → e,权重tadd(b-1,e,t);}// 执行SPFA算法求最长路径spfa();// 输出从0到n的最长路径长度cout<<dist[n]<<endl;return0;}

【运行结果】

9 4 1 4 2 4 6 2 8 9 2 3 5 2 5
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/24 11:56:51

终极完整版元素周期表:免费高清中文资源大放送

还在为化学学习找不到清晰的元素周期表而烦恼吗&#xff1f;这份免费的高清中文版元素周期表PDF文件将彻底解决你的困扰&#xff01;无论你是学生、教师还是科研人员&#xff0c;这份精心整理的元素周期表资源都能为你的学习和工作提供有力支持。 【免费下载链接】元素周期表高…

作者头像 李华
网站建设 2026/6/24 18:36:03

Redis Hash类型深度解析:结构、原理与实战应用

引言 Redis的Hash&#xff08;哈希&#xff09;类型是存储结构化数据的理想选择&#xff0c;它提供了键值对的集合&#xff0c;非常适合存储对象数据。在本篇博客中&#xff0c;我们将全面探讨Redis Hash类型的内部机制、命令集、性能优化以及实际应用场景。 一、Redis Hash基本…

作者头像 李华
网站建设 2026/6/25 15:46:02

Intel RealSense深度相机标定技术:从原理到实践的全方位指南

Intel RealSense深度相机标定技术&#xff1a;从原理到实践的全方位指南 【免费下载链接】librealsense Intel RealSense™ SDK 项目地址: https://gitcode.com/GitHub_Trending/li/librealsense 深度相机在现代计算机视觉应用中扮演着关键角色&#xff0c;而精确的标定…

作者头像 李华
网站建设 2026/6/25 13:33:49

COMSOL压电陶瓷悬臂梁振动仿真3D模型:稳态频域研究、结构优化与能量采集自供能资料大全

comsol压电陶瓷悬臂梁振动仿真3维模型。 稳态、频域研究&#xff0c;不同结构下的特征频率完美求解。 物理场耦合完整&#xff0c;具有参数扫描功能&#xff0c;可开展结构优化。 附赠详细参考资料&#xff0c;是入手压电换能器仿真的好资料。 压电陶瓷 振动 能量采集 自供能压…

作者头像 李华
网站建设 2026/6/25 15:13:39

深度定制:在富文本编辑器中封装实用的 AI 写作助手功能

最近在开发一个多模态AI项目&#xff0c;里面有一个AI写作功能&#xff0c;就是将AI写作辅助功能集成到富文本编辑器中&#xff0c;该功能的交互方式方式灵活多变&#xff0c;需要思考清楚不同的使用场景和提升用户体验&#xff0c;这是实现该功能的难点。本文将深入探讨如何基…

作者头像 李华
网站建设 2026/6/25 15:11:47

React Fiber 架构详解:为什么它能解决页面卡顿问题?

React Fiber 架构详解&#xff1a;为什么它能解决页面卡顿问题&#xff1f;本文从问题与目标、核心数据结构、调度与中断、渲染阶段与提交阶段、优先级与 lanes、并发特性到常见误区与优化建议&#xff0c;全景式拆解 React Fiber&#xff0c;为何它能够显著降低交互卡顿并提升…

作者头像 李华