36.1 party(CF623D)

很是鸡贼的一道题

首先要明确一点,抓人是有策略,而不是随机的,可以认为等同于按一个给定的顺序猜人,那么这时猜中的概率就只是抓住这个人的概率了

对于每一次猜测,因为使用最优策略,所以每一步都猜当前使游戏结束几率最大的那个人

令\(q_i=1-p_i\)即为第\(i\)个人不被猜中的概率

则第\(i\)个人在被猜\(j\)次后已经被猜中过的概率即为\((1-q_i^j)\)

那么这时游戏已经结束的概率即为\(\prod\limits_i(1-q_i^j)\)

于是模拟每轮,贪心找出对结束概率增长贡献最大的人,把猜他的次数++

要求精度为\(10^-9\),模拟\(300000\)次即可满足精度要求(这是最鸡贼的地方

最后……

\(\huge{戒瞎开long\ long}\)

36.2 fibonotci(CF575A)

看到每一项都由前面的两项结合指定的系数得到,而且有循环节,那么每个循环节的运算矩阵是可以用矩阵乘法维护的

但是有修改操作,所以需要一种支持高效修改与“求和”的方法

那么线段树是可以满足这个需求的

按循环节跳,每次如果发现当前循环节里有被修改的位置就先改,算完再改回来

很难写,至少对我来说……

36.3 parking(CF480E)

悬线法,似乎和玉蟾宫类似,只不过变成了求最大正方形,而且带修改

悬线法就是每个点求向上/向下延伸的最远距离,

首先考虑求最大正方形的方式:从大到小枚举区间长度,然后看这个长度的区间中是否存在一个区间,使它中向上/下延伸长度的两个最小值之和不小于这个区间的长度,那么这样找到的第一个符合条件的区间长度就是此时的最大正方形边长

那也肯定不是\(O(qn^3)\)求啊!

发现如果从前往后推,答案是不断减少的,但我们并不知道每个时刻的答案是在地图的哪个位置出现的,所以必须遍历每一个位置才能得到答案,效率极低

又发现其实刚开始就可以推出最后的状态,而如果从后往前推,也就是把点一个一个删去,可能出现改变答案的位置就只有删去的这个点所在的一行

那么可以把修改离线存下来,然后倒着来,首先用\(O(n^2)\)dp求,这样每次就只用\(O(n^2)\)查找一行的答案改变,因为答案是从后往前是单调不减的,每次从上一个答案开始,\(O(n^2)\)更新答案

查找区间最值的操作可以用线段树来维护,这样每次更新答案用当前行建一次树,更新答案时就可以\(O(n\log n)\)了

36.4 ant

高斯消元的主元法优化,留坑……

37.1 简单题

首先发现\((a+b)\)的值和\(c\)的值之和是不变的,而最后的答案只关心\(c\),所以可以把\((a+b)\)和\(c\)的值分开考虑

发现在\(%(a+b+c)\)意义下,加倍的操作和减去另一个数的操作是等价的,所以直接处理一个快速幂与原数相乘即可

37.2 斗地主

神仙思路:把每张牌正反两面的权值连边,那么在存在环的联通块中,所有值都能取,而在一棵树中,必有一个值取不到

所以并查集处理每个联通块,并记录每个联通块的最大/最小值,如果有一棵树权值的值域被询问区间包含,那么询问区间里必有一值取不到

可以用线段树处理区间包含的问题,就能做到\(O(q\log n)\)

37.3 变化的树

每次操作可以看作是树上加了一个等差数列

那么可以用线段树维护差分数组,然后树链剖分一下

38.1 理发

每一次大于\(h_i\)的头发被推平,那么之前等于\(h_i\)的头发与这些头发构成的逆序对就会被全部消除

那么处理出每个高度的头发贡献的逆序对个数,然后在\(j=0\)时答案为\(0\),那么相当于给上面处理出来的数组做一个前缀和

38.2 T形覆盖

考虑将"T"形转化成十字删一角,并重新建图,那么将摆放方式固定的十字连自环,否则与和他有角相交的点连边,用边表示这两个十字其中一个要删这个点占用,那么最终的方案每个点都要至多占有一条边,且每条边都必须被一个点占有,否则无解。

分析这个条件可以发现有解时每个联通块都是树或基环树:

  • 如果是基环树,那么每个点都可以恰好占有一条边,这块区域能被覆盖满
  • 如果是树,那么必须有一个点要放弃一条边,一个点得删,所以贪心取这个联通块里最小的权值减去

39.2 dequexlis

发现其实操作后的最长上升子序列长度就是把原序列镜像复制一遍再求到的长度

因为严格上升,所以可以保证一个数不会在两边被重复取到

39.3 最大前缀和

把数抽象成在网格上的移动,从原点出发,\(-1\)为向上走,\(1\)为向右走,那么经过的点中横纵坐标之差最小的位置就代表了最大前缀和

发现所有答案一样的点都在一条直线上,那么可以用卡特兰数时学的那个套路沿直线对称再组合数求出不超过某条对角线的方案总数,再记录上一条总数,相减得到恰好最大值为每个值时的答案

W2.1 袜子分配

选出一双袜子,一共有\(\binom{2n}{2}\)种方案,能取到一双袜子有\(2n\)中方案,取\(n\)次答案即为\(\frac{2n^2}{\binom{2n}{2}}\)即为\(\frac{n}{2n-1}\)种方案

W3.2 路径难题

明显需要求一个最短路,但条件比较复杂,考虑建图的方式:对于每条公交线路,所有站台向一个虚点连权值为票价的边,并从这个虚点向所有站台连权值为\(0\)的边

建好边后跑\(dijkstra\)即可,因为要上取整,注意每次坐公交时需要把当前的距离先上取整一下再乘回去,最后一起除以\(r\)就是对的

「考试」联赛模拟36-39,noip晚间小测2-3的更多相关文章

  1. 「NOWCODER」CSP-S模拟赛第3场

    「NOWCODER」CSP模拟赛第3场 T1 货物收集 题目 考场思路即正解 T2 货物分组 题目 考场思路 题解 60pts 算法:一维 DP 100pts 算法:一维 DP ?线段树 + 单调栈 ...

  2. 「考试」noip模拟9,11,13

    9.1 辣鸡 可以把答案分成 每个矩形内部连线 和 矩形之间的连线 两部分 前半部分即为\(2(w-1)(h-1)\),后半部分可以模拟求(就是讨论四种相邻的情况) 如果\(n^2\)选择暴力模拟是有 ...

  3. 「考试」CSP-S 2020

    乱扯 爆炸的过程是这样的 写了\(2.5h\)的\(T1\)过不去大样例,自闭了 决定调\(T2\)然后过了样例但事实上写的完全是假的 这个时候突然\(T1\)灵光一闪就没再看\(T2\)了 然后就一 ...

  4. 「数据结构」:模拟指针(simulated pointer)

    模拟指针,也就是清华严老师<数据结构-C语言描述>中的静态链表,静态链表的引用是使用一段连续的存储区还模拟指针的功能,可以有效的利用一段连续内存进行一定范围内可变的子链表的空间分配,此数据 ...

  5. [考试反思]0907NOIP模拟测试39:角落

    题比较简单,但是做的非常烂. T1是个愚蠢的找规律组合数快速幂,数组开小了(看错数据范围) T2题目保证联通没看见,hack掉了正解. T3也挺蠢的,但是打乱了,思路不是很清晰导致丢了50分. 只能说 ...

  6. 「考试」weight

    正解是树剖. 首先Kru求最小生成树. 然后分别考虑树边和非树边的答案. 首先是非树边,非树边链接的两个点在MST上能够构成一条链. 这条链上最大的那条边-1就是这条边的答案. 为什么. 模拟Kru的 ...

  7. 「考试」$5T$

    啊因为最近题实在是好啊,只能四五篇四五篇写了. T1. 括号序列的确简单. 当我们维护左右$cnt$后. 到一个左括号的地方的话. 答案就是:$$\sum\limits_{i=1}^{min(lc,r ...

  8. 「考试」小P的生成树

    考场上想到一半正解,没想到随机化,不然也许能够$A$掉. 题目所说的其实就是向量加法,求模长最长的向量生成树. 我们考虑对于两个向量,必然在平行边形对角线方向上,他们的投影和是最大的,长度就是对角线长 ...

  9. 「考试」num (破800纪念)

    是第800题啦. 怎么说,$rvalue$学长写的已经挺好的了,我在这里做一点补充,写一点理解. 但是这道题真的值得写一下题解,毕竟一百行也算是数论工程题了. 定义函数 $Fp(k,n)$为$n$中$ ...

随机推荐

  1. python数据分析使用matplotlib绘图

    matplotlib绘图 关注公众号"轻松学编程"了解更多. Series和DataFrame都有一个用于生成各类图表的plot方法.默认情况下,它们所生成的是线形图 %matpl ...

  2. 深入学习OpenCV文档扫描及OCR识别(文档扫描,图像矫正,透视变换,OCR识别)

    如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 下面 ...

  3. kali xHydra使用

    简介: Hydra是一款登录爆破神器,Hydar几乎可以爆破各种协议的登录,比如windows的远程桌面.ssh.ftp.路由交换设备等等. Hydar在kali linux默认已经安装. 大概介绍一 ...

  4. 分布式监控系统之Zabbix宏、模板和自定义item

    前文我们聊了下zabbix的基础使用,包括主机的添加.监控项.触发器.action以及告警通知的配置,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/140073 ...

  5. SQL SERVER 数据库自动备份及定期删除设置步骤

    现在任何的软件都离不了一个数据库,数据的利用价值越来越大,为了避免数据宕机造成的数据丢失情况的产生,定期对数据库进行备份是必须要做的工作,下面将介绍SQL Server自带的数据库备份方法,希望可以帮 ...

  6. 如何剔掉 sql 语句中的尾巴,我用 C# 苦思了五种办法

    一:背景 1. 讲故事 这几天都在修复bug真的太忙了,期间也遇到了一个挺有趣bug,和大家分享一下,这是一块sql挺复杂的报表相关业务,不知道哪一位大佬在错综复杂的 嵌套 + 平行 if判断中sql ...

  7. 《Spring Boot 实战纪实》之需求管理

    目录 前言 (思维篇)人人都是产品经理 1.需求文档 1.1 需求管理 1.2 如何攥写需求文档 1.3 需求关键点文档 2 原型设计 2.1 缺失的逻辑 2.2 让想法跃然纸上 3 开发设计文档 3 ...

  8. 微信公众号平台Url Token EncodingAESKey 注意点

    最近公司让我开发微信公众号平台扫码登录,同步用户信息于PC端,所做的过程当中遇到了一些坑,做完了就总结一下需要注意的点,如若大家开发过程中遇到同样的问题,可以借鉴! 第一:配置域名 作用:配置域名为了 ...

  9. 冷门的HTML - tabindex 的作用

    冷门的HTML - tabindex 的作用 HTML 的 tabindex 属性开发过程中一般不会使用到,最近开发中有个需求兼顾富交互,便总结了一下.本篇文章同时收录在我的[前端知识点]中,Gith ...

  10. php接收base64数据生成图片并保存

    public function base64(){ //接收base64数据 $image= $_POST['imegse']; //设置图片名称 $imageName = "25220_& ...