拒绝听搜索.etc水过的。数据太弱了(尽管考场上我凭借数据太水骗了好多分)

我讲的思路和下发的题解一样。(因为我不会所以只能颓它啊)

首先你要相信这题精灵就100个,真的只有100个,这次数据范围没错。

然后你的复杂度就可以愉快地用m了。

因为小精灵就m个所以实际上有用的位置也最多只有m+1个(算起点)

可以证明:如果路径中存在折返,那么一定发生在某一个小精灵的位置上。

因为如果你在其它位置折返,那一定不如在上一个经过的小精灵处就折返,这样才能更早到达对面的位置

也可以证明:如果过程中走过的坐标最小是l最大是r,那么接下来要么就是直线前往l左面的第一只小精灵,要么就是直线前往r右面的第一只小精灵。

因为l到r区间内的精灵都被你以前路过时抓走了,如果你想要更多的分数就需要扩展你的活动区间。

而从(l,r)->(l,r+2)可以分解成(l,r)->(l,r+1)->(l,r+2)来逐步考虑,所以现在的问题就是dp统计一次往两边扩展1个位置。

dp定义已经出来了,tl[i][j][k]表示已经走过区间j~k,目前时间为i的最大分数,此时在左端点。tr[i][j][k]同理只不过在右端点。

然而数组开不开,需要离散化一下有小精灵的坐标。

由本层向下一层转移就好。

理论复杂度爆踩搜索,实际运行时间被爆踩。

 #include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
struct qs{int x,v,t;friend bool operator<(qs a,qs b){return a.x<b.x;}}q[];
int tl[][][],tr[][][],x[],ref[],n,m,k,o,p,e[][],ans;
int main(){
scanf("%d%d%d",&n,&k,&m);x[]=k;
for(int i=;i<=m;++i)scanf("%d%d%d",&q[i].x,&q[i].v,&q[i].t),x[i+]=q[i].x;
sort(x+,x++m);memset(tl,0xa0,sizeof tl);memset(tr,0xa0,sizeof tr);
for(int i=;i<=m+;++i)if(!ref[x[i]])x[++o]=x[i],ref[x[i]]=o;
for(int i=;i<=m;++i)if(q[i].x==k)p+=q[i].v;
tl[][ref[k]][ref[k]]=tr[][ref[k]][ref[k]]=p;
for(int i=;i<=m;++i)e[q[i].t][ref[q[i].x]]+=q[i].v;
for(int i=;i<=o;++i)for(int j=;j;--j)e[j][i]+=e[j+][i];
for(int t=,T;t<=;++t)for(int i=;i<=o;++i)for(int j=i;j<=o;++j){
T=t+x[i]-x[i-];if(i!=&&T<=)tl[T][i-][j]=max(tl[T][i-][j],tl[t][i][j]+e[T][i-]);
T=t+x[j]-x[i-];if(i!=&&T<=)tl[T][i-][j]=max(tl[T][i-][j],tr[t][i][j]+e[T][i-]);
T=t+x[j+]-x[j];if(j!=o&&T<=)tr[T][i][j+]=max(tr[T][i][j+],tr[t][i][j]+e[T][j+]);
T=t+x[j+]-x[i];if(j!=o&&T<=)tr[T][i][j+]=max(tr[T][i][j+],tl[t][i][j]+e[T][j+]);
tl[t+][i][j]=max(tl[t+][i][j],tl[t][i][j]);
tr[t+][i][j]=max(tr[t+][i][j],tr[t][i][j]);
}
for(int i=;i<=o;++i)for(int j=i;j<=o;++j)ans=max(ans,max(tl[][i][j],tr[][i][j]));
printf("%d\n",ans);
}

码量有点大

可爱精灵宝贝:dp的更多相关文章

  1. 可爱精灵宝贝 DP/爆搜

    考崩了 T2 这题是个DP的好题啊(凡是我不会的都是好题,所以所有的题都是好题(雾)) DP思路: 分析性质:这个人对于路上的小精灵,能收集就一定会收集,即他每次都会收集这一段区间的小精灵 然后就考虑 ...

  2. [jzoj 5770]【2018提高组模拟A组8.6】可爱精灵宝贝 (区间dp)

    传送门 Description Branimirko是一个对可爱精灵宝贝十分痴迷的玩家.最近,他闲得没事组织了一场捉精灵的游戏.游戏在一条街道上举行,街道上一侧有一排房子,从左到右房子标号由1到n. ...

  3. [CSP-S模拟测试]:可爱的精灵宝贝(搜索)

    题目描述 $Branimirko$是一个对可爱精灵宝贝十分痴迷的玩家.最近,他闲得没事组织了一场捉精灵的游戏.游戏在一条街道上举行,街道上一侧有一排房子,从左到右房子标号由$1$到$n$.刚开始玩家在 ...

  4. NOIP模拟 18

    这次时间分配不合理,沉迷大模拟无法自拔 虽然A了但是根本就没给T3留时间555 T3如果有时间看看数据范围应该可以想到QJ掉20分的555 T1 引子 打这题的时候感觉自己在做图像处理.. 然后调了各 ...

  5. 2019.8.12 NOIP模拟测试18 反思总结

    写个博客总是符合要求的对吧 回来以后第一次悄悄参加考试,昨天全程围观… 然后喜提爆炸120分wwwwwwwww T1用了全机房最慢的写法,导致改掉死循环T掉的一个点以后还是死活过不了最后一个点.T2全 ...

  6. 英语口语练习系列-C19-喜欢某人

    简单词汇 1. chair [tʃeə(r)] n. 椅子 chair = ch + air拼读的时候ch发音以及air发音 [ ] sit on a chair 坐在椅子上 [ ] a table ...

  7. 【LOJ】#2024. 「JLOI / SHOI2016」侦查守卫

    题解 童年的回忆! 想当初,这是我考的第一次省选,我当时初二,我什么都不会,然后看着这个东西,是不是能用我一个月前才会的求lca,光这个lca我就调了一个多小时= =,然后整场五个小时,我觉得其他题不 ...

  8. (四)DIH导入结构化数据

    (四)DIH导入结构化数据 目前大多数的应用程序将数据存储在关系数据库(如oracle.sql server .mysql等).xml文件中.对这样的数据进行搜索是很常见的应用.所谓的DataImpo ...

  9. html+css第八篇滑动门和可爱的css精灵

    滑动门: 滑动门并不是一项全新的技术,它是利用背景图像的可层叠性,并允许他们在彼此之上进行滑动,以创造一些特殊的效果. CSS精灵 CSS Sprites在国内很多人叫CSS精灵,是一种网页图片应用处 ...

随机推荐

  1. 1.Eclipse下载、常用配置、快捷键

    Eclipse官网下载:https://www.eclipse.org/downloads/packages/ 自动补全 位置:Eclipse——Window——Perferences——Java—— ...

  2. Python函数参数与参数解构

    1 Python中的函数 函数,从数学的角度来讲是,输入一个参数,经过一个表达式的处理后得到一个结果的输出,即就是x-->y的一个映射.同样,在Python或者任何编程语言中,函数其实就是实现一 ...

  3. Hyper-V 下linux虚拟机静态IP上网配置的两种方式(2)

    工作需要,搭建linux环境,网上搜了两种Hyper-V配置linux静态IP及上网的方式,记录一下,方便查阅,如下设置网络共享方式: win10下使用hyper-v在本机安装linux虚拟机后,网络 ...

  4. vc++中输入表的免杀

    国外的杀毒软件一般会把特征码定位在PE文件的输入表函数(也就是源码里我们调用了的API函数)上, 我们对付这种查杀的方法就是在源码里对API函数进行动态调用,对一个函数动态调用之后,本来以输入 表函数 ...

  5. PMBOK(第六版) PMP笔记——《十三》第十三章(项目干系人管理)

    PMBOK(第六版) PMP笔记——<十三>第十三章(项目干系人管理) 第十三章 项目干系人管理: 了解干系人的需要和期望.解决实际发生的问题.管理利益冲突.促进干系人合理参与 项目决策和 ...

  6. java-try,return和finally相遇时的各种情况

    今天碰到了这样一个问题:使用try,return和finally会碰到的各种情况1,try中有return时,执行顺序:2,try和finally中都有return时,执行顺序:3,运算代码在fina ...

  7. if循环判断

    if循环判断 if-else循环的语法格式 if 逻辑判断句: ​ 代码块 # 缩进表示所属关系 else 逻辑判断句: ​ 代码块 if 和elif同时使用来做多层判断 if 逻辑判断式: 代码块 ...

  8. SpringBoot之ConfigurationProperties 源码解读

    前言 ConfigurationProperties 是SpringBoot引入的一个和外部配置文件相关的注解类.它可以帮助我们更好的使用外置的配置文件属性. 源码解析 属性注入到Java类 @Tar ...

  9. java集合第一节,List简单介绍

    Java中List集合的常用方法   List接口是继承Collection接口,所以Collection集合中有的方法,List集合也继承过来. package 集合; import java.ut ...

  10. maven 打包 spring boot 生成docker 镜像

    1.所使用材料 ,spring boot 项目 基于maven ,maven 工具, docker工具 ps:为啥使用 docker 公司微服务需要启动太多,有两个优点吧! 1.方便管理,2.减少服务 ...