Problem List(其实这几场全是附中出的)

这场比赛的题目相当有价值,特别是前两题,相当的巧妙。

A.路径二进制

数据范围这么小,当然是搜索。

\(30pts:\)大力搜索出奇迹,最后统计答案的时候拿一个桶存一下已经统计了哪些数,由于\(d<=20\),所以\(result<=2^20\),所以还是存的下的。

\(60pts:\)我们发现重复状态其实非常之多,我们加上一个记忆化进行剪枝:\(vis[i][t][S]\)表示\(i\)号点、时间是\(t\)、当前数是\(S\)是否已经访问过,如果已经访问过那就可以回溯了。时间复杂度和空间复杂度都是\(O(nd2^d)\)的,时间上可以过满数据,但是空间会被卡。

\(100pts:\)相当巧妙的方法来优化空间:我们在搜索时进行折半,只从一开始搜索长度为\(\frac{1}{2}d\)的链并用状压存下是否可达存下来,然后分别在每个点往外搜索长度为\(\frac{1}{2}d\)的链并状压存下,最后遍历每个点暴力合并前后两段就可以了。空间复杂度是\(n^22^{\frac{1}{2}d}+2^d\)的,时间是\(n^22^d\)的。

B.停车场

\(20pts:\)悬线法可以解决静态的平面最大全0矩阵问题。当然也可以用\(DP\)解决:设\(f_{i,j}\)为在结点\((i,j)\)向左上能延伸的最大方形的边长,\(h_{i,j}\)为向上能有多少个空位,\(r_{i,j}\)是向左的空位,于是得到\(f_{i,j}=min\{r_{i,j},h_{i,j},f_{i-1,j-1}+1\$。复杂度\)O(n^2m)$。

\(70pts:\)你会发现没有这一档部分分,这个是我考场上乱搞搞出来的分数。你会发现一个神奇的性质:

假设我们要在\(now\)这个点放一辆车,那么它只会对它右下角的点的\(DP\)值产生影响,并且下面这种已经放过车的右下方的位置的\(DP\)值也没有影响,所以我们要更新的点的数量就比较有限了。关于如何遍历这个奇形怪状的东西,我们只需要一行一行枚举,存一下当前遇到的最左边的车的横坐标,以后便利的横坐标都要小于这个值就行了)。另外我们要动态查询\(f\)的最大值,这个东西用一棵权值线段树当成平衡树跑就可以实现\(log\)级别,所以总的时间复杂度最劣是\(O(n^2dlogn)\)的,但是只要随机它能飞起来。

\(100pts:\)简直精妙到不得了的,时间复杂度应该是最劣\(n^2logn+mn\)的。答案显然是递减的,并且答案的值域就只有\([1,2000]\),还是满足决策单调性的!这就使人浮想联翩了。由于加上一辆车可能会破坏很多答案,破坏性质不优美,即使用平衡树维护啥的都很吃力,所以我们反过来想:我们移走一辆车,看看包括它的矩形最大是多少的,这个时候两个答案取\(max\)是满足交换律的,相当优美。

但是光光这样还是相当困难。我们再加上一个小小的转换:记录上一次的答案是\(lastans\),那么我这次就依次验证有没有矩形包含这个新空格且大小为\(lastans+1\)、\(lastans+2\)······直到不合法为止。这个可以用平衡树来解决:设\(r1_{i,j}\)、\(r2\)、\(r3\)、\(r4\)分别是它向四个方向能延伸多少,那么我在指定空格的那个纵列上依次扫下来,看看这个高度为\(lastans+1\)的窗口内的向左、向右的最小值加起来是否能够大于等于\(lastans+1\)。显然一个空格只会影响它所在的那一横一竖的\(r\),暴力修改即可。

它的时间复杂度显然是均摊的,最劣是\(n^2logn+mn\),据说用并查集可以优化到\(n^2\alpha\)的。

这启发我们在答案值域很小、满足单调性和决策单调性的时候可以使用反过来的、判定性的方法解决问题。

学军中学csp-noip2020模拟5的更多相关文章

  1. 2016 Multi-University Training Contest 8 solutions BY 学军中学

    1001: 假设有4个红球,初始时从左到右标为1,2,3,4.那么肯定存在一种方案,使得最后结束时红球的顺序没有改变,也是1,2,3,4. 那么就可以把同色球都写成若干个不同色球了.所以现在共有n个颜 ...

  2. Java多线程 编写三各类Ticket、SaleWindow、TicketSaleCenter分别代表票信息、售票窗口、售票中心。 售票中心分配一定数量的票,由若干个售票窗口进行出售,利用你所学的线程知识来模拟此售票过程。

    package com.swift; import java.util.ArrayList; import java.util.HashMap; import java.util.List; impo ...

  3. 学军NOIP2016模拟赛1

    GTMD这么水的一套题没有AK T1:妥妥的二分答案,贪心check. T2:问题可以转化为最长上升(还是下降我记不住了)子序列. T3:发现点被覆盖上的顺序是一定的.求出这个顺序,第一个操作在线段树 ...

  4. 学军NOI训练13 T3 白黑树

    唉,大学军有自己的OJ就是好,无限orz 只有周六的比赛是开放的囧,这场比赛最后因为虚拟机卡住没有及时提交…… 否则就能让大家看到我有多弱了…… 前两题题解写的很详细,可以自己去看,我来随便扯扯T3好 ...

  5. 2019学军集训记&PKUWC2020游记

    题解:https://www.cnblogs.com/gmh77/p/12051260.html 集训(×) 被虐(√) Day1 二段考 Day2 绝对不鸽 没那回事 还在路上 其实就是咕了两天 晚 ...

  6. NOIP2020 模拟赛 B 组 Day6

    非常巧妙的一场模拟赛,比较偏向于 Atcoder 的风格,考场上做出了 A .C 两题. A. 礼物购买 排完序后一个个礼物地枚举时间复杂度是\(\Theta(nm)\)的,不能接受.但是注意到,若当 ...

  7. 从零开始学Python04作业思路:模拟ATM电子银行

    标签(空格分隔):Python 一,程序文件说明 程序分为5个组成部分 bin:放置Python程序的启动接口文件 通过Python命令启动文件夹内文件即正常执行Python程序 例如:ATM_sta ...

  8. 20150127 学军集训 day1

    day1 就直接考试... 和说好的不一样啊 第一题看都没怎么看就pass了,构造的题我一向没什么把握.然后瞟到第三题有30分可做,虽然要写的代码很大...反正我是写习惯了..期间纠结了一会还写了一个 ...

  9. ZJOI2019Round#1

    考的这么差二试基本不用去了 不想说什么了.就把这几天听课乱记的东西丢上来吧 这里是二试乱听课笔记ZJOI2019Round#2 ZJOI Round#1 Day1 M.<具体数学>选讲 罗 ...

随机推荐

  1. SpringCloud-SpringBoot-SpringCloudAlibaba对应版本选择

    一.SpringCloud-SpringBoot 对应的版本选择 SpringCloud官网常规方式只能查看最新的几个版本信息 https://spring.io/projects/spring-cl ...

  2. CSP踩被记

    本来想起个清新脱俗的标题,但碍于语文功底不行,于是光明正大嫖了LiBoyi的高端创意,把这篇博客命名为踩被记. Day -6 用假暴力把真正解拍没了,伤心.Rp有点低 Day -4 信息学考,\(py ...

  3. 零基础小白要如何跟好的学习嵌入式Linux

    作为一个新人,怎样学习嵌入式Linux?被问过太多次,特写这篇文章来回答一下. 在学习嵌入式Linux之前,肯定要有C语言基础.汇编基础有没有无所谓(就那么几条汇编指令,用到了一看就会). C语言要学 ...

  4. 云效Flow如何实现阿里云ECS多环境发布

    一.背景 云效Flow基于标签功能实现阿里云ECS多环境发布,在软件开发和部署过程中,我们的软件往往需要在不同的运行环境中运行,例如:开发人员本地开发环境.测试团队的测试环境.还有类生产环境和生产环境 ...

  5. Vulnhub实战-dr4g0n b4ll靶机👻

    Vulnhub实战-dr4g0n b4ll靶机 地址:http://www.vulnhub.com/entry/dr4g0n-b4ll-1,646/ 描述:这篇其实没有什么新奇的技巧,用到的提权方式就 ...

  6. 对JavaScript中局部变量、全局变量和闭包的理解

    对js中局部变量.全局变量和闭包的理解 局部变量 对于局部变量,js给出的定义是这样的:在 JavaScript函数内部声明的变量(使用 var)是局部变量,所以只能在函数内部访问它.(该变量的作用域 ...

  7. hdu 1847 Good Luck in CET-4 Everybody! (简单博弈)

    题意: n张牌,双方轮流抓取.每人每次抓取的牌数必须是2的幂次(1,2,4,8...). 最后抓完的人胜. 思路 : 考虑剩3张牌,后手胜. 考虑3的倍数.假设先抓者当轮抓2x 张,2x %3等于1或 ...

  8. Downward API —— 在容器内部获取 Pod 信息

    我们知道,每个 Pod 在被超过创建出来之后,都会被系统分配唯一的名字.IP地址,并且处于某个 Namespace 中,那么我们如何在 Pod 的容器内获取 Pod 的这些重要信息呢? 答案就是使用 ...

  9. 关于Asp.net core配置信息读取的源码分析梳理

    概述 我们都知道asp.net core配置信息的读取离不开IConfigurationSource和IConfigurationProvider这两个类,ConfigurationSource可以提 ...

  10. Redis 专栏(使用介绍、源码分析、常见问题...)

    一.介绍相关 说Redis : 介绍Redis特性,使用场景,使用Jedis操作Redis等. 二.源码分析 1. 数据结构 Redis源码分析(sds):Redis自己封装的C语言字符串类型. Re ...