[Offer收割]编程练习赛1 hihocoder 1270 建造基地 (完全背包)
来源:互联网 发布:bose蓝牙音响 知乎 编辑:程序博客网 时间:2024/04/30 14:18
时间限制:10000ms
单点时限:1000ms
内存限制:256MB
- 样例输入
22 2 2 21 31 22 2 2 21 21 1
- 样例输出
8No Answer
描述
在遥远的未来,小Hi成为了地球联邦外空间联合开发工作组的一员,前往一颗新发现的星球开发当地的重金属资源。
为了能够在当地生存下来,小Hi首先要建立一个基地。建立基地的材料可以直接使用当地的石材和富裕的重金属资源。基地建设分为N级,每一级都需要达成K的建设值后才能够完成建设,当前级别的建设值溢出后不会影响到下一级的建设。
小Hi可以产出的重金属资源按照精炼程度分为M级,根据开采的数量和精炼的工艺,可以将获取精炼程度为第i级的重金属资源的成本量化为Ai。
在建设第1级基地时,一块精炼度为i的重金属可以提供Bi的建设值,此后基地的级别每提高一级,建设值将除以T并下取整(整除)。
现给定N、M、K、T、A[]和B[],小Hi需要你帮助他计算他完成基地建设的最小成本。
输入
输入包含多组测试数据。
输入的第一行为一个整数Q,表示测试数据的组数。
每组测试数据的第一行为4个整数N、M、K和T,意义如前文所述。
接下来的一行为M个整数,分别表示A1~AM。
接下来的一行为M个整数,分别表示B1~BM。
对于100%的数据,满足1<=N<=10,1<=M<=100,1<=K,T<=104
对于100%的数据,满足Ai和Bi均为32位整型范围内的正整数
对于100%的数据,满足1<=Q<=10
输出
对于每组测试数据,如果小Hi最终能够完成基地建设,则输出小Hi完成基地建设所需要的最小成本,否则输出“No Answer”。
题目链接:http://hihocoder.com/problemset/problem/1270
题目分析:比较裸的完全背包,dp[i]表示建设值为i时的最小成本
#include <cstdio>#include <algorithm>#define ll long longusing namespace std;int const INF = (1 << 30);int const MAX = 1e4 + 5;int n, m, k, t;int a[105], b[105];ll dp[MAX];int main(){ int T; scanf("%d", &T); while(T --) { scanf("%d %d %d %d", &n, &m, &k, &t); for(int i = 1; i <= m; i++) scanf("%d", &a[i]); for(int i = 1; i <= m; i++) scanf("%d", &b[i]); ll ans = 0; bool flag = true; for(int i = 0; i < n; i++) { for(int j = 0; j < MAX; j++) dp[j] = INF; dp[0] = 0; ll cur = INF; for(int j = 1; j <= m; j++) { for(int l = 0; l <= k; l++) { if(b[j] + l > k) cur = min(cur, dp[l] + a[j]); else dp[b[j] + l] = min(dp[b[j] + l], dp[l] + a[j]); } } cur = min(cur, dp[k]); if(cur == INF) { flag = false; printf("No Answer\n"); break; } ans += cur; for(int j = 1; j <= m; j++) b[j] /= t; } if(flag) printf("%lld\n", ans); }}
0 0
- [Offer收割]编程练习赛1 hihocoder 1270 建造基地 (完全背包)
- HiHoCoder #1270 : 建造基地 [Offer收割]编程练习赛1 【完全背包】
- HihoCoder 1270 建造基地(完全背包)
- Hihocoder 1270 建造基地(完全背包)
- hihocoder #1270 建造基地 完全背包
- hihocoder [Offer收割]编程练习赛19
- hihocoder [Offer收割]编程练习赛24
- [Offer收割]编程练习赛1 hihocoder 1268 九宫 (DFS)
- hihoCoder[Offer收割]编程练习赛1题目解析
- hihocoder-建造基地(完全背包)
- [Offer收割]编程练习赛2 hihocoder 1273 (DFS + 状压)
- hihoCoder[Offer收割]编程练习赛2题目解析
- hihoCoder 1285 [Offer收割]编程练习赛3-3
- hihoCoder[Offer收割]编程练习赛3题目解析
- hihocoder[Offer收割]编程练习赛3及参考
- hihocoder[Offer收割]编程练习赛5及参考
- hihocoder[Offer收割]编程练习赛6及参考
- hihocoder-- 热门号码([Offer收割]编程练习赛37)
- 关于指针作函数参数
- TTL、RS232、CMOS电平
- 算法 for_each
- HDU 1269 迷宫城堡 强联通分量模板存放处
- 关于System类的使用方法【小程序】
- [Offer收割]编程练习赛1 hihocoder 1270 建造基地 (完全背包)
- 进程间通信——管道
- 新浪微博时间转换工具类
- 会场安排问题(贪心算法)
- Android知识点整理
- 剑指offer-顺时针打印矩阵
- 7种qsort排序方法
- 2016.3.5【初中部 NOIP提高组 】模拟赛A
- sqlite优化