news 2026/6/17 1:03:31

洛谷 P1510:精卫填海 ← 动态规划

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷 P1510:精卫填海 ← 动态规划

【题目来源】
https://www.luogu.com.cn/problem/P1510

【题目描述】
精卫终于快把东海填平了!只剩下了最后的一小片区域了。同时,西山上的木石也已经不多了。精卫能把东海填平吗?
事实上,东海未填平的区域还需要至少体积为 v 的木石才可以填平,而西山上的木石还剩下 n 块,每块的体积和把它衔到东海需要的体力分别为 k 和 m。精卫已经填海填了这么长时间了,她也很累了,她还剩下的体力为 c。

【输入格式】
输入文件的第一行是三个整数:v,n,c。
从第二行到第 n+1 行分别为每块木石的体积和把它衔到东海需要的体力。​​​​​​​

【输出格式】
输出文件只有一行,如果精卫能把东海填平,则输出她把东海填平后剩下的最大的体力,否则输出 Impossible(不带引号)。​​​​​​​

【输入样例一】
100 2 10
50 5
50 5

【输出样例一】
0

【输入样例二】
10 2 1
50 5
10 2​​​​​​​

【输出样例二】
Impossible

【数据范围】
对于 20% 的数据,0<n≤50;
对于 50% 的数据,0<n≤1000;
对于 100% 的数据,0<n≤
10^4,所有读入的数均属于 [0,10^4],最后答案不大于 c。

【算法分析】
● 闫氏 DP 分析法:https://www.bilibili.com/video/BV1X741127ZM
● 最后一步法:https://www.bilibili.com/video/BV1xb411e7ww

【算法代码】
f[j] 表示容量为 j 时能获得的最大价值。

#include <bits/stdc++.h> using namespace std; const int maxn=1e+5; int val[maxn],vol[maxn],f[maxn]; int v,n,c; int main() { cin>>v>>n>>c; for(int i=1; i<=n; i++) cin>>val[i]>>vol[i]; for(int i=1; i<=n; i++) { for(int j=c; j>=vol[i]; j--) { f[j]=max(f[j],f[j-vol[i]]+val[i]); } } for(int i=0; i<=c; i++) { if(f[i]>=v) { cout<<c-i; return 0; } } cout<<"Impossible"; return 0; } /* in: 10 2 1 50 5 10 2 out: Impossible */





【参考文献】
https://www.cnblogs.com/Hoyoak/p/11373507.html
https://www.acwing.com/file_system/file/content/whole/index/content/12355190/
https://www.cnblogs.com/lipeiyi520/p/12293384.html
https://blog.csdn.net/hnjzsyjyj/article/details/147405964





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

TileLang-Ascend学习周回顾与激励活动

学习周圆满收官&#xff0c;实践征程开启&#xff5c;TileLang-Ascend五天学习周回顾与奖励计划公布 为期五天的 TileLang-Ascend学习周 已于2月6日圆满落幕。课程自2月2日开播以来&#xff0c;吸引了众多开发者与算法工程师的持续关注与参与。在TileLang核心开发团队老师的带…

作者头像 李华
网站建设 2026/5/30 2:11:13

智能客服Agent实战:基于LLM的高效对话系统架构与避坑指南

背景痛点&#xff1a;规则引擎的“天花板” 过去三年&#xff0c;我先后维护过两套基于规则引擎的客服系统。它们用 DSL 描述“if-关键词 then 答案”的决策树&#xff0c;上线初期响应速度极快&#xff0c;CPU 占用不到 5%。然而随着 SKU 膨胀到 3 万&#xff0c;长尾问题占比…

作者头像 李华
网站建设 2026/5/30 22:08:09

CANN算子量化——AIGC轻量化部署的低精度算子适配方案

cann组织链接&#xff1a;https://atomgit.com/cann ops-nn仓库链接&#xff1a;https://atomgit.com/cann/ops-nn 随着AIGC技术向边缘端、移动端等轻量化场景渗透&#xff0c;智能终端、边缘服务器等设备的硬件资源有限&#xff08;显存小、计算能力弱&#xff09;&#xff0…

作者头像 李华