【问题描述】

发鸠之山,其上多柘木。有鸟焉,其状如乌,文首,白喙,赤足,名曰精卫,其名自詨。是炎帝之少女,名曰女娃。女娃游于东海,溺而不返,故为精卫。常衔西山之木石,以堙于东海。——《山海经》

精卫终于快把东海填平了!只剩下了最后的一小片区域了。同时,西山上的木石也已经不多了。精卫能把东海填平吗?

事实上,东海未填平的区域还需要至少体积为v的木石才可以填平,而西山上的木石还剩下n块,每块的体积和把它衔到东海需要的体力分别为k和m。精卫已经填海填了这么长时间了,她也很累了,她还剩下的体力为c。

这题是让我们用最小的体力搬最大的体积。

我一开始没用最小的体力,

就对了一个点

很尴尬

看看我只对了一个点的代码吧:

#include<iostream>
#include<cstdio>
using namespace std;
int v,n,c,ans;
int f[],tj[],tl[];
int main()
{
cin>>v>>n>>c;
for(int i=;i<n;i++)
{
cin>>tj[i];
cin>>tl[i];
}
ans=c;//记剩余体力的变量
for(int i=;i<n;i++)
{
for(int j=c;j>=;j--)
{
if(j>=tl[i])//是否有足够的体力搬运
{
if(f[j-tl[i]]+tj[i]>f[j])//搬过来是否体积会更大
{
f[j]=f[j-tl[i]]+tj[i];
if(j==c)//是否体力为c
{
//cout<<ans<<" "<<i<<endl;
ans-=tl[i];//减去需要的体力
//cout<<ans<<endl;
}
}
}
}
}
//cout<<f[c]<<" "<<n<<endl;
if(v-f[c]>)//如果不能填完,输出 Impossible
{
cout<<"Impossible"<<endl;
return ;
}
cout<<ans<<endl;//输出剩余的体力
return ;
}

在死磕了几天后

突然发现我求的是体力为c,谁出填完剩余最多的体力

我改了代码:

#include<iostream>
#include<cstdio>
using namespace std;
int v,n,c;
int f[],tj[],tl[];
int main()
{
cin>>v>>n>>c;
for(int i=;i<n;i++)
{
cin>>tj[i];
cin>>tl[i];
}
for(int i=;i<n;i++)
{
for(int j=c;j>=;j--)
{
if(j>=tl[i])//是否有足够的体力搬运
{
f[j]=max(f[j-tl[i]]+tj[i],f[j]);//求出当前体力最多可以搬运的最大体积
}
}
}
for(int i=;i<c;i++)//循环,搜索可以填满的最小体力
{
if(f[i]>=v)//如果填满了,就输出剩余的体力
{
cout<<c-i<<endl;
return ;
}
}
cout<<"Impossible"<<endl;
return ;
}

然后,就A了(*^-^*)

P1050 精卫填海的更多相关文章

  1. P1050

    问题 F: P1050 时间限制: 1 Sec  内存限制: 128 MB提交: 37  解决: 27[提交][状态][讨论版] 题目描述 一个字符串A的子串被定义成从A中顺次选出若干个字符构成的串. ...

  2. P1510 精卫填海

    P1510 精卫填海二分答案二分背包容量,判断能否满足v.判断的话就跑01背包就好了. #include<iostream> #include<cstdio> #include ...

  3. 洛谷 P1510 精卫填海

    洛谷 P1510 精卫填海 题目描述 [版权说明] 本题为改编题. [问题描述] 发鸠之山,其上多柘木.有鸟焉,其状如乌,文首,白喙,赤足,名曰精卫,其名自詨.是炎帝之少女,名曰女娃.女娃游于东海,溺 ...

  4. VIJOS-P1625 精卫填海

    JDOJ 1587 VIJOS-P1625 精卫填海 https://neooj.com/oldoj/problem.php?id=1587 洛谷 P1510 精卫填海 https://www.luo ...

  5. 洛谷P1050 循环【java大数】

    题目:https://www.luogu.org/problemnew/show/P1050 题意:给定一个数$n$,问$n$的幂次的最低$k$位的循环节是多少. 思路:这真是我做过最难的java大数 ...

  6. P1050 螺旋矩阵

    P1050 螺旋矩阵 转跳点:

  7. tyvj P1050 最长公共子序列

    题目链接:http://tyvj.cn/p/1050 题解: 裸题,只是为了测试LCS模板写对没有…… #include<cstdio> #include<cstring> # ...

  8. luogu P1510 精卫填海

    题目描述 [版权说明] 本题为改编题. [问题描述] 发鸠之山,其上多柘木.有鸟焉,其状如乌,文首,白喙,赤足,名曰精卫,其名自詨.是炎帝之少女,名曰女娃.女娃游于东海,溺而不返,故为精卫.常衔西山之 ...

  9. 洛谷P1510 精卫填海

    //01背包 求背包内物品价值超过某一定值时的最小体积 #include<bits/stdc++.h> using namespace std; ; ; int n,v_tot,w_tot ...

随机推荐

  1. scanf中的%[^\n]%*c格式

    scanf中的%[^\n]%*c格式 (2011-02-19 16:12:38) 转载▼ 标签:  控制字符 空白字符 字符串 变量 整数 it 分类: C语言编程 文章转载自http://blog. ...

  2. Python-17-作用域

    python有一个名为vars的内置函数,它返回变量关联的不可见的字典: >>> x = 1  >>> scope = vars()  >>> s ...

  3. django drf 10大请求序列化方法

    ## 整体单改 路由层.模型层.序列化层不需要做修改,只需要处理视图层:views.py ```python"""1) 单整体改,说明前台要提供修改的数据,那么数据就需要 ...

  4. Spring9——通过用Aware接口使用Spring底层组件、环境切换

    通过用Aware接口使用Spring底层组件 能够供我们使用的组件,都是Aware的子接口. ApplicationContextAware:实现步骤:             (1)实现Applic ...

  5. caffe的python接口学习(2)生成solver文件

    caffe在训练的时候,需要一些参数设置,我们一般将这些参数设置在一个叫solver.prototxt的文件里面 有一些参数需要计算的,也不是乱设置. 假设我们有50000个训练样本,batch_si ...

  6. windows 下 node 安装 react

    当前node.npm都已安装了. 可是在执行 安装 react的时候总是报错 最后会生成一个报错的txt文件(  <npm-@googlegroups.com>npm-debug.log) ...

  7. 《UNIX环境高级编程》(APUE) 笔记第七章 - 进程环境

    7 - 进程环境 Github 地址 1. main 函数 C 程序总是从 main 函数 开始执行: int main(int argc, char *argv[]); \(argc\) 为命令行参 ...

  8. linux根据进程查端口,根据端口查进程

    [root@test_environment src]# netstat -tnllup   能显示对应端口和进程 Active Internet connections (only servers) ...

  9. css hack原理及常用hack

    原理:利用不同浏览器对CSS的支持和解析结果不一样编写针对特定浏览器样式.常见的hack有1)属性hack.2)选择器hack.3)IE条件注释 IE条件注释:适用于[IE5, IE9]常见格式如下 ...

  10. CSS 3中-webkit-, -moz-, -o-, -ms-这些私有前缀的含义和兼容

    css3作为页面样式的表现语言,增加了很多新的属性,但是部分css3属性在一些浏览器上还处于试验阶段,所以为了有效的显示css3的样式,对应不同的浏览器内核需要不同的前缀声明,例如: -moz- :F ...