[AH2017/HNOI2017] 大佬

大佬每天给出的伤害是固有的,设dp[i,j]表述使得前i天结束时我的自信为j最少做水题的天数。D=max(i-dp[i,j])就是总共拿来给伤害的最大天数。打伤害一类是固定的伤害1,一类是积累伤害打出(最多用两次)。不妨暴力搜索积累伤害的情形c(d,f),即我们用了d天积累了f的伤害。

若D>=hp每次伤害1就好了(直接判);
若存在c使得f<=hp且f+D-d>=hp,这样累计一次大佬就好了(扫一遍);
若存在c1c1使得f1+f2<=hp且d1+d2<=D且f1+f2+D-d1-d2>=hp,这样累计两次大佬就好了;先枚举c1(d1,f1),则c2满足d2<=D-d1,f2<=hp-f1,同时也应最大化f2-d2以最大化总伤害。

噫要是没有d2<=D-d1的限制,我们可以把所有的c按照f排序,然后决策单调性.jpg(反过来的)就非常好做了。然后就可以发现若d1+d2>D,因为f1+f2<=hp,则f1+f2+D-d1-d2<hp不可能构成解。一语成谶

#include <bits/stdc++.h>
#define fr first
#define sc second
#define ll long long 
using namespace std;const int N=1e2+10;
const int M=3e6+10;
const int inf=0x3f3f3f3f;int n,m,mc,tot,a[N],w[N];
int D,C[N],MAXC,dp[N][N];struct {int cnt,head[M];struct kNode{int x,y,lst;} nd[M+1];void insert(int x,int y) {int t=(100LL*x+y)%M;nd[++cnt]=(kNode){x,y,head[t]},head[t]=cnt;}bool find(int x,int y) {int t=(100LL*x+y)%M;for(int i=head[t]; i; i=nd[i].lst) if(x==nd[i].x&&y==nd[i].y) return 1;return 0;}
} vis;
struct sNode{int f,d,l;};
queue<sNode> Q; 
pair<int,int> V[M];int main() {scanf("%d%d%d",&n,&m,&mc);for(int i=1; i<=n; ++i) scanf("%d",a+i);for(int i=1; i<=n; ++i) scanf("%d",w+i);memset(dp,inf,sizeof dp);dp[0][mc]=0;for(int i=1; i<=n; ++i) {for(int j=a[i]; j<=mc; ++j) {int x=j-a[i];dp[i][x]=min(dp[i][x],dp[i-1][j]); x=min(mc,x+w[i]);dp[i][x]=min(dp[i][x],dp[i-1][j]+1);}for(int j=0; j<=mc; ++j) D=max(D,i-dp[i][j]);}for(int i=1; i<=m; ++i) scanf("%d",C+i);MAXC=*max_element(C+1,C+m+1);Q.push((sNode){1,1,0});while(Q.size()) {sNode x=Q.front(); Q.pop();if(x.d==D||x.f>=MAXC) continue;Q.push((sNode){x.f,x.d+1,x.l+1});if(x.l>1&&1LL*x.f*x.l<=MAXC&&!vis.find(x.f*x.l,x.d+1)) {V[++tot]=make_pair(x.f*x.l,x.d+1);vis.insert(V[tot].fr,V[tot].sc);Q.push((sNode){V[tot].fr,V[tot].sc,x.l});}}sort(V+1,V+tot+1);//printf("%d %d %d\n",D,MAXC,tot);for(int i=1; i<=m; ++i) {if(C[i]<=D) {puts("1"); continue;}int flag=0,mx=-inf;for(int j=tot,k=1; j>=1; --j) {while(k<tot&&V[k].fr+V[j].fr<=C[i]) mx=max(mx,V[k].fr-V[k].sc),++k;if(V[j].fr-V[j].sc+mx+D>=C[i]) {flag=1; break;}if(V[j].fr<=C[i]&&V[j].fr+D-V[j].sc>=C[i]) {flag=1; break;}}printf("%d\n",flag);}return 0;
}

转载于:https://www.cnblogs.com/nosta/p/10954408.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/483288.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

杨振宁:宇宙有没有造物者?

来源&#xff1a;一刻talks未来智能实验室的主要工作包括&#xff1a;建立AI智能系统智商评测体系&#xff0c;开展世界人工智能智商评测&#xff1b;开展互联网&#xff08;城市&#xff09;大脑研究计划&#xff0c;构建互联网&#xff08;城市&#xff09;大脑技术和企业图谱…

基于STM32的DS1302实时时钟模块应用及原理介绍

在嵌入式系统中&#xff0c;实时时钟模块是一个常见的功能模块&#xff0c;用于记录和管理系统的时间信息。DS1302是一款低功耗、具有多种功能的实时时钟芯片&#xff0c;被广泛应用于各种电子产品中。本文将介绍基于STM32微控制器的DS1302实时时钟模块的应用及原理&#xff0c…

发布一个npm包

前言 我这里是写了一个vue轮播图插件&#xff0c;因此我使用了vue的脚手架工具创建一个项目&#xff0c;当然你也可以选择自己搭建脚手架。 本例中我会使用vue脚手架创建一个项目&#xff0c;并发布到npm上面去。 通过脚手架创建项目 全局安装 首先&#xff0c;要创建项目&…

三大运营商扎堆进军“元宇宙”

来源&#xff1a; 数据观综合编辑&#xff1a; 蒲蒲三大运营商集体进军“元宇宙”目前&#xff0c;除了腾讯、字节跳动、谷歌、Facebook、英伟达等科技巨头企业开启了“元宇宙”领域的布局&#xff0c;国内三大电信运营商也扎堆进入“元宇宙”玩家阵营。11月2日&#xff0c;中国…

性能测试需求调研分析方法

一、测试背景和目的 在需求调研开始&#xff0c;测试人员需要明确的测试目的&#xff0c;那么首先得清楚项目本身情况&#xff0c;针对不同的项目情况也会有不同的目的&#xff0c;根据项目情况一般可以分为以下六种情况&#xff1a; 1、完全新建系统 完全新建系统意味着被测试…

数据结构——线性表的C语言实现

文章目录1.什么是线性表&#xff1f;2.线性表的抽象数据类型3.线性表之顺序表的C语言实现4.线性表之链式表的C语言实现1.什么是线性表&#xff1f; 2.线性表的抽象数据类型 3.线性表之顺序表的C语言实现 #include<stdio.h> #include<stdlib.h>#define ElementType…

美国大学智库发布全球机器人专利态势报告

来源&#xff1a;https://cset.georgetown.edu/publication/trends-in-robotics-patents/?utm_sourceCenterforSecurityandEmergingTechnology&utm_campaigna76a55404a-TrendsinRoboticsPatents&utm_mediumemail&utm_term0_fcbacf8c3e-a76a55404a-438303754原文标…

关于技术管理者应该如何做好工作安排的一点思考

技术管理者的主要工作是带人、做事、看方向。带人是指团队人员能力的培养、团队梯队的建设等等&#xff1b;做事是指完成各项业务需求&#xff1b;看方向是指明确团队未来的发展方向和目标。 我们经常会辩论“做管理了还要不要写代码”这个话题&#xff0c;而“写代码”只是“做…

困扰热力学的三个妖精

来源&#xff1a; 集智俱乐部作者&#xff1a;Katie Robertson译者&#xff1a;潘佳栋 审校&#xff1a;张澳、梁金 编辑&#xff1a;邓一雪 热力学是一个奇怪的理论。它虽然是我们理解世界的基础&#xff0c;但与其他物理理论有很大的不同。出于这个原因&#xff0c;它被称为物…

数据结构——堆栈的C语言实现

1.什么叫堆栈&#xff1f; 2.堆栈的数据类型描述 3.堆栈顺序存储的C语言实现 #include<stdio.h> #include<stdlib.h>#define MaxSize 10 #define ERROR -1 #define ElementType int typedef struct SNode *Stack; struct SNode{ElementType Data[MaxSize];int Top…

引用数据类型(类)

提到引用数据类型&#xff08;类&#xff09;&#xff0c;其实我们对它并不陌生&#xff0c;如使用过的Scanner类、Random类。 我们可以把类的类型为两种&#xff1a; l 第一种&#xff0c;Java为我们提供好的类&#xff0c;如Scanner类&#xff0c;Random类等&#xff0c;这些…

11位院士专家建言基础研究

来源&#xff1a; 中国科学报作者&#xff1a; 陈欢欢 胡珉琦 ■本报记者 陈欢欢 胡珉琦基础研究是否完全是自由探索&#xff1f;如何加强新时代的基础研究&#xff1f;如何打造一支潜心基础研究的科研队伍&#xff1f;11月15日&#xff0c;在中国科学院加强基础研究座谈会上&a…

数据结构——队列的C语言实现

1.什么是队列&#xff1f; 2.队列的抽象数据类型描述 3.队列之顺序表的C语言实现 #include<stdio.h> #include<stdlib.h>#define MaxSize 5 #define ElementType int #define ERROR -1typedef struct QNode *Queue; struct QNode{ElementType Data[MaxSize];int r…

java连接sqlserver报错

使用Java进行项目开发&#xff0c;一般是使用MySQL数据库&#xff0c;由于项目需要本次换成了SQLServer数据库&#xff0c;在eclipse中进行连接测试时驱动类、URL地址、用户名和密码都正确&#xff0c;但是会抛出以下异常&#xff0c;无法正确连接到SQLServer数据库 com.micros…

李德毅院士:新一代人工智能十问

来源&#xff1a;智能系统学报编辑&#xff1a;王娜 审核&#xff1a;李雪莲--- 基本共识 ---智能是学习的能力&#xff0c;以及解释、解决问题的能力&#xff1b;人工智能是脱离生命体的智能&#xff0c;是人类智能的体外延伸&#xff1b;通用人工智能面向不同的情境&a…

构建之法阅读笔记

转载于:https://www.cnblogs.com/zhaoxinhui/p/10967251.html

数据结构——树的C语言实现

文章目录1.什么是树&#xff1f;2.如何判断是否是树&#xff1f;3.树的基本术语4.树的表示方法5.二叉树的定义6.特殊二叉树7.二叉树的性质8.二叉树的抽象数据类型定义9.二叉树的存储结构9.1顺序存储9.2 链表存储10.二叉树的遍历10.1 二叉树的遍历方法1.递归遍历2.层序遍历10.2 …

Gartner:为什么元宇宙商业离我们还很遥远?

来源&#xff1a;云技术(文&#xff1a;Gartner杰出研究副总裁Mark Raskino&#xff09;我记得第二人生&#xff08;Second Life&#xff09;的创始人Philip Rosedale说过&#xff1a;“请打开您的防火墙&#xff0c;进入到我们的世界中&#xff01;”他曾在台上接受过我的同事…

数据结构——二叉搜索树的C语言实现

1.什么是二叉搜索树&#xff1f; 2.二叉搜索树的操作 3.二叉搜索树的C语言实现 #include<stdio.h> #include<stdlib.h>#define ElementType int typedef struct TreeNode *BinTree; typedef BinTree Position; struct TreeNode{ElementType Data;BinTree Left;Bin…