腾讯机试题 AcWing 603 打怪兽
题目链接:https://www.acwing.com/problem/content/605/
题目大意:
略
分析:
用dp[i][j]表示用j元钱能在前i只怪兽上所能贿赂到的最大武力值。
有一种情况就是打到第i只怪兽所需的最低花费大于j,那么令dp[i][j] = -1。
那么dp[i + 1][j],也就是同样用j元钱能在前i + 1只怪兽上所能贿赂到的最大武力值是多少呢?有3种情况:
1:dp[i][j] = -1,显然dp[i + 1][j] = -1。
2:dp[i][j] < d[i + 1],也就是用j元钱在前i只怪兽上所能贿赂到的最大武力值都没有第i+1只怪兽的武力值大,这个时候必须腾出p[i + 1]元来贿赂第i + 1只怪兽,此时又有3种小情况:
(1):j < p[i + 1],这就没的说了,钱不够,直接dp[i + 1][j] = -1。
(2):dp[i][j - p[i + 1]] == -1,这说明腾不出钱来,于是dp[i + 1][j] = -1。
(3):dp[i][j - p[i + 1]] != -1,那么dp[i + 1][j] = dp[i][j - p[i + 1]] + d[i + 1],不存在选择,必须贿赂。
3:dp[i][j] >= d[i + 1],在这种情况下可以选择贿赂,也可以选择不贿赂,两种情况取最大即可,dp[i + 1][j] = max(dp[i][j], dp[i][j - p[i + 1]] + d[i + 1])。
递推关系有了,现在需要第0列的初始值:除了第0行,其他全部为-1;和第0行的初始值:全部为0。
那dp数组算出来了有啥用呢?
假设你打到第i个怪的时候,武力值为D,这时D < d[i],那你就在dp数组第i行找第一个使得dp[i][j] >= d[i]的j,这个j一定是打前i个怪最优的,因为花费比j小的金钱过不了这个boss,如果这个j能一直保持到游戏结束,那这个j就是总体最优的。
代码如下:
 #pragma GCC optimize("Ofast")
 #include <bits/stdc++.h>
 using namespace std;
 #define INIT() std::ios::sync_with_stdio(false);std::cin.tie(0);
 #define Rep(i,n) for (int i = 0; i < (n); ++i)
 #define For(i,s,t) for (int i = (s); i <= (t); ++i)
 #define rFor(i,t,s) for (int i = (t); i >= (s); --i)
 #define ForLL(i, s, t) for (LL i = LL(s); i <= LL(t); ++i)
 #define rForLL(i, t, s) for (LL i = LL(t); i >= LL(s); --i)
 #define foreach(i,c) for (__typeof(c.begin()) i = c.begin(); i != c.end(); ++i)
 #define rforeach(i,c) for (__typeof(c.rbegin()) i = c.rbegin(); i != c.rend(); ++i)
 #define pr(x) cout << #x << " = " << x << "  "
 #define prln(x) cout << #x << " = " << x << endl
 #define EL() printf("\n")
 #define SORT(c, s, t) sort(c + s, c + t + 1)
 #define LOWBIT(x) ((x)&(-x))
 #define ALL(x) x.begin(),x.end()
 #define INS(x) inserter(x,x.begin())
 #define ms0(a) memset(a,0,sizeof(a))
 #define msI(a) memset(a,inf,sizeof(a))
 #define msM(a) memset(a,-1,sizeof(a))
 #define pii pair<int,int>
 #define piii pair<pair<int,int>,int>
 #define MP make_pair
 #define PB push_back
 #define ft first
 #define sd second
 template<typename T1, typename T2>
 istream &operator>>(istream &in, pair<T1, T2> &p) {
     in >> p.first >> p.second;
     return in;
 }
 template<typename T>
 istream &operator>>(istream &in, vector<T> &v) {
     for (auto &x: v)
         in >> x;
     return in;
 }
 template<typename T1, typename T2>
 ostream &operator<<(ostream &out, const std::pair<T1, T2> &p) {
     out << "[" << p.first << ", " << p.second << "]" << "\n";
     return out;
 }
 typedef long long LL;
 typedef unsigned long long uLL;
 typedef pair< double, double > PDD;
 typedef set< int > SI;
 typedef vector< int > VI;
 const double EPS = 1e-;
 const int inf = 1e9 + ;
 const LL mod = 1e9 + ;
 const int maxN = 1e5 + ;
 const LL ONE = ;
 //! n 表示怪兽的数量
 //! d[i] 表示第i只怪兽的武力值
 //! p[i] 表示收买第i只怪兽所需的金币数
 //! ans 最小花费
 int n, p[], ans;
 LL d[];
 //! dp[i][j] 表示用j元钱能在前i只怪兽上所能贿赂到的最大武力值
 LL dp[][];
 int main(){
     INIT();
     cin >> n;
     For(i, , n) cin >> d[i];
     For(i, , n) cin >> p[i];
     For(i, , n) dp[i][] = -; 
      For(j, ,  * n) {
         For(i, , n) {
             if(dp[i - ][j] == -) dp[i][j] = -;
             else if(dp[i - ][j] < d[i]) {
                 if(j < p[i]) dp[i][j] = -;
                 else if(dp[i - ][j - p[i]] == -) dp[i][j] = -;
                 else dp[i][j] = dp[i - ][j - p[i]] + d[i];
             }
             else dp[i][j] = max(dp[i - ][j], dp[i - ][j - p[i]] + d[i]);
         }
     }
     // maxD 最大武力值
     // maxDi 最大武力值下标
     LL maxD = -, maxDi;
     For(i, , n) {
         if(d[i] > maxD) {
             maxD = d[i];
             maxDi = i;
         }
     }
     ans = lower_bound(dp[maxDi], dp[maxDi] +  * n, maxD) - dp[maxDi]; 
     cout << ans << endl;
     return ;
 }
腾讯机试题 AcWing 603 打怪兽的更多相关文章
- 腾讯面试题:10G 个整数,乱序排列,要求找出中位数。内存限制为 2G。
		腾讯面试题:10G 个整数,乱序排列,要求找出中位数.内存限制为 2G. 题目和基本思路都来源网上,本人加以整理. 题目:在一个文件中有 10G 个整数,乱序排列,要求找出中位数.内存限制为 2G.只 ... 
- 腾讯笔试题:小Q硬币组合
		腾讯有一道机试题: 大概意思是: 小Q非常富有,拥有非常多的硬币,小Q的拥有的硬币是有规律的,对于所有的非负整数K,小Q恰好> 各有两个数值为2^k,的硬币,所以小Q拥有的硬币是1,1,2,2, ... 
- 腾讯面试题 腾讯面试题:给40亿个不重复的unsigned int的整数,没排过序的,然后再给一个数,如何快速判断这个数是否在那40亿个数当中?
		腾讯面试题:给40亿个不重复的unsigned int的整数,没排过序的,然后再给一个数,如何快速判断这个数是否在那40亿个数当中? 这个题目已经有一段时间了,但是腾讯现在还在用来面试.腾讯第一次面 ... 
- 九度oj题目&吉大考研11年机试题全解
		九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ... 
- Java基础机试题
		package day8;import java.util.Scanner;/** * Java基础机试题 * @author:lyrand * */public class convert { ... 
- 牛客网华为机试题之Python解法
		牛客网华为机试题之Python解法 第1题 字符串最后一个单词的长度 a = input().split(" ") print(len(a[-1])) 第2题 计算字符个数 a = ... 
- 算法题14 小Q歌单,牛客网,腾讯笔试题
		算法题14 小Q歌单,牛客网,腾讯笔试题 题目: 小Q有X首长度为A的不同的歌和Y首长度为B的不同的歌,现在小Q想用这些歌组成一个总长度正好为K的歌单,每首歌最多只能在歌单中出现一次,在不考虑歌单内歌 ... 
- 算法题16 贪吃的小Q 牛客网 腾讯笔试题
		算法题16 贪吃的小Q 牛客网 腾讯笔试题 题目: 链接:https://www.nowcoder.com/questionTerminal/d732267e73ce4918b61d9e3d0ddd9 ... 
- [51nod1670] 打怪兽
		lyk在玩一个叫做“打怪兽”的游戏.游戏的规则是这样的.lyk一开始会有一个初始的能量值.每次遇到一个怪兽,若lyk的能量值>=怪兽的能量值,那么怪兽将会被打败,lyk的能量值增加1,否则lyk ... 
随机推荐
- Linux的常见问题解答和管理技巧
			Linux的常见问题解答和管理技巧 一. 如何建立多用户 提醒大家一句,别一直使用root用户,因为root用户在系统中有着至高无上的权力,一不小心就可能破坏系统.比如我们想删除/temp目录下的文件 ... 
- 搭建golang学习环境,并用chrome headless获取网页内容
			想用go练练手(我是win7系统,已从https://studygolang.com/dl 下载了go安装包并安装,比较简单,不详述. 但作为边民,没法go get ,又不敢用梯子,幸亏有爱心大牛们的 ... 
- UVA11059-Maximum Product(动态规划)
			Problem UVA11059-Maximum Product Accept:4769 Submit:38713 Time Limit: 3000 mSec Problem Descriptio ... 
- 转://oracle Wallet在expdp/impdp中使用场景
			oracle Wallet的使用(即内部加密技术TDE(Transparent Data Encryption )) 1. TDE是Oracle10gR2中推出的一个新功能,使用时要保证Oracle版 ... 
- centos7  mongodb安装
			参考文档 http://www.runoob.com/mongodb/mongodb-connections.html https://www.cnblogs.com/layezi/p/7290082 ... 
- vue组件详解——使用props传递数据
			每天学习一点点 编程PDF电子书.视频教程免费下载:http://www.shitanlife.com/code 在 Vue 中,父子组件的关系可以总结为 props向下传递,事件向上传递.父组件通过 ... 
- Home Assistant-自动化设备
			触发器(trigger) 条件(condition) 动作(action) 自动化中的模板(template) 触发器(trigger) 时间(time)触发器时间触发器在指定的时间触发规则,可以是某 ... 
- BuildTools Overview
			SCons Pros: Based on a full-fledged programming language, Python. This means you can make the build ... 
- Pycharm远程调试服务器代码(使用Pipenv管理虚拟环境)
			准备工作 1.随便准备一个项目工程,在本地用Pipenv创建一个虚拟环境并生成Pipfile和pipfile.lock文件,如下: 2.准备一台服务器,我这里使用阿里云的ECS SSH连接上 $ ss ... 
- 【转】MySQL中的行级锁,表级锁,页级锁
			在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足. 在数据库的锁机制中介绍过,在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引 ... 
