news 2026/6/15 10:55:38

算法竞赛备考冲刺必刷题(C++) | 洛谷 P1250 种树

作者头像

张小明

前端开发工程师

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

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

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

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


【题目来源】

撸狗:P1250 种树 - 洛谷

【题目描述】

路边的地区被分割成块,并被编号成1 , 2 , … , n 1, 2, \ldots,n1,2,,n。每个部分为一个单位尺寸大小并最多可种一棵树。

每个居民都想在门前种些树,并指定了三个号码b bbe eet tt。这三个数表示该居民想在地区b bbe ee之间(包括b bbe ee)种至少t tt棵树。

居民们想种树的各自区域可以交叉。你的任务是求出能满足所有要求的最少的树的数量。

【输入】

输入的第一行是一个整数,代表区域的个数n nn

输入的第二行是一个整数,代表房子个数h hh

3 33到第( h + 2 ) (h + 2)(h+2)行,每行三个整数,第( i + 2 ) (i + 2)(i+2)行的整数依次为b i , e i , t i b_i, e_i, t_ibi,ei,ti,代表第i ii个居民想在b i b_ibie i e_iei之间种至少t i t_iti棵树。

【输出】

输出一行一个整数,代表最少的树木个数。

【输入样例】

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

【输出样例】

5

【算法标签】

《洛谷 P1250 种树》 #贪心# #排序# #差分约束#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=30005,M=N*3;// 最大顶点数和边数intn,m;// n: 范围[0,n], m: 区间约束数量inth[N],e[M],w[M],ne[M],idx;// 链式前向星存储图intdist[N];// 最长距离数组boolst[N];// 标记顶点是否在队列中/** * 添加有向边 * @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));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}// 即: S_i - S_{i-1} ≥ 0// 建边: i-1 → i,权重0add(i-1,i,0);// 约束2: S_i - S_{i-1} ≤ 1// 即: S_{i-1} - S_i ≥ -1// 建边: i → i-1,权重-1add(i,i-1,-1);}// 添加区间约束for(inti=1;i<=m;i++){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/15 11:44:37

人工智能之数学基础 线性代数:第一章 向量与矩阵

人工智能之数学基础 线性代数 第一章 向量与矩阵 文章目录人工智能之数学基础 线性代数前言一、基本定义1. 向量&#xff08;Vector&#xff09;2. 矩阵&#xff08;Matrix&#xff09;二、基本运算1. 向量/矩阵加减法示例&#xff08;矩阵&#xff09;&#xff1a;Python 实现…

作者头像 李华
网站建设 2026/6/15 15:44:08

重塑Java工程效能:全流程智能开发平台实践解析

在Java企业级开发中&#xff0c;研发人员常面临工作流程割裂的挑战&#xff1a;从需求分析、接口定义、数据建模到代码实现&#xff0c;需在不同工具与上下文间频繁切换&#xff0c;不仅效率受限&#xff0c;也易产生设计不一致与细节遗漏。针对这一痛点&#xff0c;专注于Java…

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

Spring Boot + Kafka 实战:从入门到避坑,小白也能轻松上手!

视频看了几百小时还迷糊&#xff1f;关注我&#xff0c;几分钟让你秒懂&#xff01;一、为什么我们需要 Kafka&#xff1f;在现代微服务架构中&#xff0c;系统之间的通信不能总是“你等我、我等你”——这会导致性能瓶颈甚至雪崩。Kafka 就是一个高性能、高吞吐、可扩展的消息…

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

UGC链游开发白皮书:NFT道具合约的6层架构与80%项目忽视的权限风险

引言&#xff1a;当UGC遇见NFT&#xff0c;链游的“造物革命”在传统游戏中&#xff0c;玩家花费数百小时打造的装备可能因服务器关闭或账号封禁化为乌有&#xff1b;而在区块链游戏&#xff08;链游&#xff09;中&#xff0c;NFT技术让虚拟道具成为玩家真正拥有的数字资产。更…

作者头像 李华
网站建设 2026/6/14 20:03:40

Restormer 去雨(Deraining)任务代码运行全流程

本文将系统梳理基于 Restormer 模型实现图像去雨&#xff08;Deraining&#xff09;任务的完整流程&#xff0c;涵盖代码执行逻辑、核心文件架构及关键操作步骤&#xff0c;为实验的理解与复现提供清晰指引。若需获取适配新版环境的 Restormer 配置教程&#xff08;含避坑要点&…

作者头像 李华
网站建设 2026/6/15 15:26:59

鸿蒙 Flutter 安全组件开发:加密输入框与脱敏展示组件

一、引言 在鸿蒙&#xff08;HarmonyOS&#xff09;应用开发中&#xff0c;用户敏感信息&#xff08;如密码、手机号、身份证号&#xff09;的安全防护是核心需求之一。基于 Flutter 跨平台框架开发鸿蒙应用时&#xff0c;原生组件往往无法直接满足 “输入加密” 和 “展示脱敏…

作者头像 李华