传送门:

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));
}
}

最新文章

  1. sshd安装
  2. ooad单例模式-Singleton
  3. Spark运行流程概述
  4. 关于静态库和动态库的理解(C++)
  5. [BZOJ 2738] 矩阵乘法 【分块】
  6. Samba服务器
  7. Vijos 1083 小白逛公园(线段树)
  8. 微软微服务eShopOnContainers示例之EventBusRabbitMq解析与实践
  9. 201521123101 《Java程序设计》第2周学习总结
  10. Phoenix与Hive学习资料
  11. truffle框架的简单使用
  12. CF1101F Trucks and Cities
  13. Python之函数第三篇
  14. C#轻量级高性能日志组件EasyLogger
  15. RSA密钥生成、加密解密、签名验签
  16. go语言中make和new的区别
  17. NPOI 导出excel 通用方法
  18. haproxy开启日志功能
  19. SSL handshake failed: SSL error: Key usage violation in certificate has been detected.
  20. 二叉排序树实现(C++封装)

热门文章

  1. private SortedDictionary&lt;string, object&gt; Dic_values = new SortedDictionary&lt;string, object&gt;();
  2. EF搭建数据库
  3. Kinect 开发 —— 骨骼数据与彩色影像和深度影像的对齐
  4. 不固定高宽的 div 水平垂直居中
  5. nodejs基础部分(一)
  6. mkfs---创建Linux文件系统
  7. Perl OOP
  8. Android Studio配置SVN 以及使用代码管理
  9. hdu 1533 Going Home 最小费用最大流 入门题
  10. libev环境