caioj 1086 动态规划入门(非常规DP10:进攻策略)
一开始看到题目感觉很难
然后看到题解感觉这题贼简单,我好像想复杂了
就算出每一行最少的资源(完全背包+二分)然后就枚举就好了。
#include<cstdio>
#include<algorithm>
#include<cstring>
#define REP(i, a, b) for(int i = (a); i < (b); i++)
using namespace std;
const int MAXN = 212345;
const int MAXM = 112;
int n, m, k;
int w[MAXM], p[MAXM], q[MAXN];
int f[MAXN], list[MAXN];
int main()
{
	scanf("%d%d%d", &m, &n, &k);
	REP(i, 0, m) scanf("%d", &w[i]);
	REP(i, 0, m) scanf("%d", &p[i]);
	REP(i, 0, n) scanf("%d", &q[i]);
	REP(i, 0, m)
		REP(j, w[i], k + 1)
			f[j] = max(f[j], f[j-w[i]]+p[i]);
	int head = 0, sum = 0, ans = 0;
	REP(i, 0, n)
	{
		int t = lower_bound(f, f + k + 1, q[i]) - f;//不是二分答案都用stl二分,简单又不会错
		sum += t; list[i] = t;
		while(sum > k) sum -= list[head++]; //注意这里是while
		ans = max(ans, i - head + 1);
	}
	printf("%d\n", ans);
	return 0;
}caioj 1086 动态规划入门(非常规DP10:进攻策略)的更多相关文章
- caioj 1080 动态规划入门(非常规DP4:乘电梯)(dp数组更新其他量)
		我一开始是这么想的 注意这道题数组下标是从大到小推,不是一般的从小到大推 f[i]表示从最高层h到第i层所花的最短时间,答案为f[1] 那么显然 f[i] = f[j] + wait(j) + (j ... 
- caioj 1087 动态规划入门(非常规DP11:潜水员)(二维背包)
		这道题的难点在于价值可以多. 这道题我一开始用的是前面的状态推现在的状态 实现比较麻烦,因为价值可以多,所以就设最大价值 为题目给的最大价值乘以10 #include<cstdio> #i ... 
- 洛谷P1280 && caioj 1085 动态规划入门(非常规DP9:尼克的任务)
		这道题我一直按照往常的思路想 f[i]为前i个任务的最大空暇时间 然后想不出来怎么做-- 后来看了题解 发现这里设的状态是时间,不是任务 自己思维还是太局限了,题做得太少. 很多网上题解都反着做,那么 ... 
- caioj 1084 动态规划入门(非常规DP8:任务安排)(取消后效性)
		这道题的难点在于,前面分组的时间会影响到后面的结果 也就是有后效性,这样是不能用dp的 所以我们要想办法取消后效性 那么,我们就可以把影响加上去,也就是当前这一组加上了s 那么就把s对后面的影响全部加 ... 
- caioj 1083 动态规划入门(非常规DP7:零件分组)(LIS)
		这道题题目给的顺序不是固定的 所以一开始要自己排序,按照w来排序 后来只要看l就可以了 然后求最长下降子序列即可(根据那个神奇的定理,LIS模板里有提到) #include<cstdio> ... 
- caioj 1082 动态规划入门(非常规DP6:火车票)
		f[i]表示从起点到第i个车站的最小费用 f[i] = min(f[j] + dist(i, j)), j < i 动规中设置起点为0,其他为正无穷 (貌似不用开long long也可以) #i ... 
- caioj 1081 动态规划入门(非常规DP5:观光游览)
		这道题和前面的分组的题有点像 就是枚举最后一组的长度. 然后组数可以在第一层循环也可以在第二层循环 我自己的话就统一一下在第一层循环吧 然后这道题题意我一直没理解清楚,浪费了很多时间,写复杂了 同时初 ... 
- caioj 1079 动态规划入门(非常规DP3:钓鱼)(动规中的坑)
		这道题写了我好久, 交上去90分,就是死活AC不了 后来发现我写的程序有根本性的错误,90分只是数据弱 #include<cstdio> #include<algorithm> ... 
- caioj 1078 动态规划入门(非常规DP2:不重叠线段)(状态定义问题)
		我一开始想的是前i个区间的最大值 显然对于当前的区间,有不选和选两种情况 如果不选的话,就继承f[i-1] 如果选的话,找离当前区间最近的区间取最优 f[i] = max(f[i-1, f[j] + ... 
随机推荐
- java高级——生产者消费者问题
			多线程是一个很重要的应用,本节讲述多线程中同步问题 public class ThreadDemo { public static void main(String[] args) { Resourc ... 
- 004.JMS消息结构
			JMS的消息结构类似于HTTP请求的结构分为三部分: 消息头 消息属性 消息体 下面分别说明三部分的内容标准. 1. 消息头 消息头包含消息的识别信息和路由信息,其标准属性如下: 下面介绍的参数都可以 ... 
- EL与JSTL学习(二)——JSTL技术
			1.JSTL概述 JSTL(JSP Standard Tag Library),JSP标准标签库,可以嵌入在jsp页面中使用标签的形式完成业务逻辑等功能. jstl出现的目的同el一样也是要代替jsp ... 
- MySQL用户添加和分配权限
			mysql数据库insertdelete服务器file mysql> grant 权限1,权限2,…权限n on 数据库名称.表名称 to 用户名@用户地址 identified by ‘连接口 ... 
- STM8S103内存详析
			STM8S103的RAM有1k,0x00-0x3FF(RAM和ROM统一编址),其中0x200-0x3ff共512个字节默认为堆栈,剩余的低端512个字节又分为了Zero Page和剩余的RAM(简称 ... 
- double int 类型的区别
			内部组织格式不同: po [NSString stringWithFormat:@"%d", f] 107886912 (lldb) po [NSString stringWith ... 
- 前端学习之路——gulp篇
			一.构建gulp环境 1.下载nodejs gulp基于node.js,要通过nodejs的npm安装gulp,所以要先安装node.js环境.(英文官网/中文官网链接). 通过cmd命令窗口确定安装 ... 
- SpringBoot学习笔记(13)----使用Spring Session+redis实现一个简单的集群
			session集群的解决方案: 1.扩展指定server 利用Servlet容器提供的插件功能,自定义HttpSession的创建和管理策略,并通过配置的方式替换掉默认的策略.缺点:耦合Tomcat/ ... 
- div控制最小高度又自适高度
			div控制最小高度又自适高度我们在用div布局的时候经常会遇到这样的一种情况:我们需要设置一个div的高度,当里面的东西超过这个高度时,让这个容器自动被撑开,也就是自适应高度.当里面的信息很少时候,我 ... 
- 学习jvm,关于MAT an internal error occurred during:"Parsing heap dump" from问题
			写了一个死循环不断的创建对象,模拟内存溢出 package com.zuo.test1; import java.util.ArrayList; import java.util.List; publ ... 
