poj 2063 Investment ( zoj 2224 Investment ) 完全背包
2024-08-25 17:19:12
传送门:
POJ:http://poj.org/problem?id=2063
ZOJ:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2224
大意:给你一堆本金,还有投资方案获得的利润。让你进行合理投资,要求若干年后获利最大。
完全背包问题。背包容量就是money,要尽量装满(不是风险投资哇,投资出去必获利)
开始天真的开了400多w(100万*1.1^40)的数组,直接TLE掉。
看了discuss里,因为给的利润为1000的整数倍,故可以将其/1000,那么背包大小也小了,时间上63ms zoj上40ms
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int MAXN=45260+10;
int dp[MAXN];
int cost[12],repay[12];
int main()
{
int T;
scanf("%d",&T);
while(T--)
{
int money,year,len;
scanf("%d%d%d",&money,&year,&len);
for(int i=1;i<=len;i++)
{
scanf("%d%d",&cost[i],&repay[i]);
cost[i]/=1000;
} for(int y=1;y<=year;y++)
{
int temp=money/1000;
for(int i=1;i<=len;i++)
{
for(int j=cost[i];j <= temp ;j++)
{
dp[j]=max(dp[j], dp[j - cost[i]]+repay[i]);
}
}
money=money+dp[temp];
}
printf("%d\n",money);
memset(dp,0,sizeof(dp));
}
}
最新文章
- sshd安装
- ooad单例模式-Singleton
- Spark运行流程概述
- 关于静态库和动态库的理解(C++)
- [BZOJ 2738] 矩阵乘法 【分块】
- Samba服务器
- Vijos 1083 小白逛公园(线段树)
- 微软微服务eShopOnContainers示例之EventBusRabbitMq解析与实践
- 201521123101 《Java程序设计》第2周学习总结
- Phoenix与Hive学习资料
- truffle框架的简单使用
- CF1101F Trucks and Cities
- Python之函数第三篇
- C#轻量级高性能日志组件EasyLogger
- RSA密钥生成、加密解密、签名验签
- go语言中make和new的区别
- NPOI 导出excel 通用方法
- haproxy开启日志功能
- SSL handshake failed: SSL error: Key usage violation in certificate has been detected.
- 二叉排序树实现(C++封装)
热门文章
- private SortedDictionary<;string, object>; Dic_values = new SortedDictionary<;string, object>;();
- EF搭建数据库
- Kinect 开发 —— 骨骼数据与彩色影像和深度影像的对齐
- 不固定高宽的 div 水平垂直居中
- nodejs基础部分(一)
- mkfs---创建Linux文件系统
- Perl OOP
- Android Studio配置SVN 以及使用代码管理
- hdu 1533 Going Home 最小费用最大流 入门题
- libev环境