p4377 [USACO18OPEN]Talent Show
2024-08-24 03:04:13
分析
经典的01分数规划问题
用01背包check即可
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<algorithm>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<queue>
#include<ctime>
#include<vector>
#include<set>
#include<map>
#include<stack>
using namespace std;
#define int long long
struct node {
int w,t;
};
node d[];
int dp[],n,m;
inline bool go(int mid){
int i,j,k;
memset(dp,-0x3f,sizeof(dp));
dp[]=;
for(i=;i<=n;i++)
for(j=m;j>=;j--)
dp[min(m,j+d[i].w)]=
max(dp[j]+d[i].t-d[i].w*mid,dp[min(m,j+d[i].w)]);
return dp[m]>=;
}
signed main(){
int i,j,s1=,s2=;
scanf("%d%d",&n,&m);
for(i=;i<=n;i++){
scanf("%d%d",&d[i].w,&d[i].t);
d[i].t*=;
}
int le=,ri=;
while(ri-le>){
int mid=(le+ri)>>;
if(go(mid))le=mid;
else ri=mid;
}
cout<<le;
return ;
}
最新文章
- php函数强大的 strtotime
- 一堆LCT板子
- 深入学习jQuery选择器系列第五篇——过滤选择器之内容选择器
- 一个Woker类,当id和name相同时,系统判断两个工人是相等的,打印工人对象时显示“工人:id和name”。
- 安卓--界面--改变image view
- 使用maven引入Apache poi jar包
- Servicestack IRequestLogger获取 IHttpRequest
- MySQL DBA修炼秘籍
- 用Filezilla往ubuntu虚拟机上传文件
- Java之多线程断点下载的实现
- C#中Split分隔字符串的应用(C#、split、分隔、字符串)
- windows 7 memcached报failed to install service or service already installed的解决方案
- Spring注解配置
- SQL实现 模糊查询(转)
- 【转】HTTP Header 详解
- 一个class标签里面有多个属性时的提取标签
- 20175314 《Java程序设计》第二周学习总结
- Excel公式中使用动态计算的地址
- phoenix技术(安装部署和基本使用)讲解
- ostream_iterator的可能实现