洛谷 P1417 烹调方案 题解
这道题是一道典型的排序dp
a[i]−b[i]∗(t+c[i])+a[j]−b[j]∗(t+c[i]+c[j])
a[j]−b[j]∗(t+c[j])+a[i]−b[i]∗(t+c[i]+c[j])a[j]-b[j]*(t+c[j])+a[i]-b[i]*(t+c[i]+c[j])a[j]−b[j]∗(t+c[j])+a[i]−b[i]∗(t+c[i]+c[j])
a[i]−b[i]∗(t+c[i])+a[j]−b[j]∗(t+c[i]+c[j])>a[j]−b[j]∗(t+c[j])+a[i]−b[i]∗(t+c[i]+c[j])a[i]-b[i]*(t+c[i])+a[j]-b[j]*(t+c[i]+c[j])>a[j]-b[j]*(t+c[j])+a[i]-b[i]*(t+c[i]+c[j])a[i]−b[i]∗(t+c[i])+a[j]−b[j]∗(t+c[i]+c[j])>a[j]−b[j]∗(t+c[j])+a[i]−b[i]∗(t+c[i]+c[j])
−b[i]∗(t+c[i])−b[j]∗(t+c[i]+c[j])>−b[j]∗(t+c[j])−b[i]∗(t+c[i]+c[j])-b[i]*(t+c[i])-b[j]*(t+c[i]+c[j])>-b[j]*(t+c[j])-b[i]*(t+c[i]+c[j])−b[i]∗(t+c[i])−b[j]∗(t+c[i]+c[j])>−b[j]∗(t+c[j])−b[i]∗(t+c[i]+c[j])
−b[i]∗t−b[i]∗c[i]−b[j]∗t−b[j]∗c[i]−b[j]∗c[j]>−b[j]∗t−b[j]∗c[j]−b[i]∗t−b[i]∗c[i]−b[i]∗c[j]-b[i]*t-b[i]*c[i]-b[j]*t-b[j]*c[i]-b[j]*c[j]>-b[j]*t-b[j]*c[j]-b[i]*t-b[i]*c[i]-b[i]*c[j]−b[i]∗t−b[i]∗c[i]−b[j]∗t−b[j]∗c[i]−b[j]∗c[j]>−b[j]∗t−b[j]∗c[j]−b[i]∗t−b[i]∗c[i]−b[i]∗c[j]
−b[j]∗c[i]>−b[i]∗c[j]-b[j]*c[i]>-b[i]*c[j]−b[j]∗c[i]>−b[i]∗c[j]
所以最后按−b[j]∗c[i]>−b[i]∗c[j]-b[j]*c[i]>-b[i]*c[j]−b[j]∗c[i]>−b[i]∗c[j]的规则进行排序就行了
#include <bits/stdc++.h>
using namespace std;
int n,t;
struct haha{
int a;
int b;
int c;
}a[];
int f[];
bool cmp(haha i,haha j){
return -j.b*i.c>-i.b*j.c;
}
int main(){
int ans=;
scanf("%d%d",&t,&n);
for(int i=;i<=n;i++) scanf("%d",&a[i].a);
for(int i=;i<=n;i++) scanf("%d",&a[i].b);
for(int i=;i<=n;i++) scanf("%d",&a[i].c);
sort(a+,a+n+,cmp);
for(int i=;i<=n;i++){
for(int j=t;j>=a[i].c;j--){
f[j]=max(f[j],f[j-a[i].c]+a[i].a-a[i].b*j);
ans=max(ans,f[j]);
}
}
printf("%d\n",ans);
return ;
}
最新文章
- ZooKeeper1 利用虚拟机搭建自己的ZooKeeper集群
- 《Kafka Stream》调研:一种轻量级流计算模式
- UVA2322
- 个性二维码开源专题<;前背景>;
- 部署Office Web Apps Server并配置其与SharePoint 2013的集成
- jQuery通过jquery.form.js插件使用AJAX提交Form表单
- ASP.NET MVC4学习笔记路由系统概念与应用篇
- Redis入门教程:特性及数据类型的操作
- oracle数据库获取指定表的列的相关信息
- 移动App測试实战:顶级互联网企业软件測试和质量提升最佳实践
- java基础练习 9
- nsqlookupd.go
- 在Unity使文字变色
- G面经Prepare: Print Zigzag Matrix
- POJ 1966 Cable TV Network (算竞进阶习题)
- python打包为独立可执行程序
- BZOJ1856或洛谷1641 [SCOI2010]生成字符串
- [ 转载 ] Java基础12--基础学习总结——数组
- Linux下删除文件系统空间不释放的问题
- controller中的路径明明书写正确,浏览器中访问的url也拼接正确,但报404