8.3-8.4NOIP模拟题总结
一:成绩
Day1 score=100+100+20
Day2 score=100+30+0
这成绩还是不行啊,仍需继续加油(抱怨一句暴力分有点少#滑稽)
二:题目分析
Day1
T1祖孙询问:
已知一棵 n 个节点的有根树。有 m 个询问。每个询问给出了一对节点的编号 x 和 y,询问 x
与 y 的祖孙关系。
分析:
这道题用一个lca随便就可以水过啦...(我一开始把祖先理解成了父亲orz)
T2比赛:
由 A 中的一个选手与 B 中的一个选手对抗。同一个人不会参加多场比赛,每个人的对手都是随机而等概率的。例如 A 队有 A1 和 A2 两个人,B 队有 B1 和 B2 两个人,那么(A1 vs B1,A2 vsB2)和(A1 vs B2,A2 vs B1)的概率都是均等的 50%。
每个选手都有一个非负的实力值。如果实力值为 X 和 Y 的选手对抗,那么实力值较强的选手所在的队伍将会获得(X-Y)^2 的得分。
求 A 的得分减 B 的得分的期望值。
分析:
这道题推了我半个小时...
我们乍一看就会觉得这是一道数学题,那我们来分析
我们固定好B队的n个人,来对A队进行排列进行一一对应,那么方案总数就是A的全排列(n!)
对于一个Ak,他对应Bj的次数是(n-1)!,怎么理解呢,就是对除了Ak的其他A进行全排列
那么(A[k]-B[j])^2对答案的总贡献=((A[k]-B[j])^2)*(n-1)!/n!=((A[k]-B[j])^2)/n
我们记录(A[k]-B[j])^2为(k,j),
对于一个Ai那么从小到大排好B,用二分查找可以算出小于等于Ai的B有k个,大于Ai的有p个,
那么对答案的贡献=(Ai,B1)+...(Ai,Bk)- ( (Ai,Bk+1) +...+(Ai,Bn) )
=Ai2*(k-p)+(b12+...+bk2)-(bk+12+...+bn2)+2a( (bk+1+...+n) - (b1+...+bk) )
那么我们对bi2和bi分别记一个前缀和即可
总复杂度O(nlogn)
T3数字
一个数字被称为好数字当他满足下列条件:
1. 它有2*n个数位,n是正整数(允许有前导0)。
2. 构成它的每个数字都在给定的数字集合S中。
3. 它前n位之和与后n位之和相等或者它奇数位之和与偶数位之和相等
例如对于n=2,S={1,2},合法的好数字有1111,1122,1212,1221,2112,2121,2211,2222这样8种。
已知n,求合法的好数字的个数mod 999983。
n≤1000,|S|≤10
分析:
考试的时候没有搞出来...想到了dp的部分却没想到组合数学的部分
我们记dp[i][j]为处理到第i个,用的数字和为j,那么dp[i][j]=∑dp[i-1][j-k]
我们看到题目要求是"命题A"或“命题B”,那就等于"命题A"+"命题B"-"命题A"且"命题B"
命题A和命题B显然就是dp[n][j]*dp[n][j](j∈[n*minnum,n*maxnum])
对于"命题A"且"命题B"可以得到的条件是"前n个数中的奇数项和"=="后n个数中的奇数项和",且"前n个数中的偶数项和"=="后n个数中的偶数项和"
那么就是dp[(n+1)/2][j]2*dp[n/2][j]2
所以答案就出来了
Day2
T1工资
聪哥在暑假参加了打零工的活动,这个活动分为 n 个工作日,每个工作日的工资为 Vi。有 m 个结算工钱的时间,聪哥可以自由安排这些时间,也就是说什么时候拿钱,老板说的不算,聪哥才有发言权!(因为聪哥是土豪,他是老板的老板)聪哥不喜欢身上一次性有太多的钱,于是他想安排一下拿钱的时间,使他一次性拿的钱中最大的最小。(最后一天一定要领钱)
分析
二分答案的水题,就不说啦
T2藏妹子之处
今天 CZY 又找到了三个妹子,有着收藏爱好的他想要找三个地方将妹子们藏起来,将一片空地抽象成一个 R 行 C 列的表格,CZY 要选出 3 个单元格。但要满足如下的两个条件:
(1)任意两个单元格都不在同一行。
(2)任意两个单元格都不在同一列。
选取格子存在一个花费,而这个花费是三个格子两两之间曼哈顿 距 离 的 和 ( 如 (x1,y1) 和 (x,y2) 的 曼 哈 顿 距 离 为 |x1-x2|+|y1-y2|)。狗狗想知道的是,花费在 minT 到 maxT 之间的方案数有多少。
答案模 1000000007。所谓的两种不同方案是指:只要它选中的单元格有一个不同,就认为是不同的方案。
分析
我一开始以为是DP。。。
对于20%的数据,我们先在三列里面上下枚举每个点的位置,预先处理好每个竖直长度的个数。
然后再枚举三列,通过之前存下的竖直长度加上枚举的横向长度计算出周长,统计答案。其实只要枚举左右列行,乘以中间的列数即可。
复杂度O(n^3)
对于100%的数据,我们之前是考虑三个点的位置,当然只能三次方,那我们如果枚举矩形的长度和宽度呢?
我们枚举一个矩形(i×j),要保证这个矩形,她最上/下的两行,最左/右的两行必须选,那我们再在中间选一行和一列,选法有(i-2)×(j-2)种
那我们选的三行三列相交出一个3×3的九宫格,填进去的方法就有6种,而这个矩形的位置有(R-i+1)*×(C-j+1)种方法
那i,j对答案的贡献就是(i-2)×(j-2)×(R-i+1)×(C-j+1)×6
复杂度O(n^2)
8.3-8.4NOIP模拟题总结的更多相关文章
- poj 1008:Maya Calendar(模拟题,玛雅日历转换)
Maya Calendar Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 64795 Accepted: 19978 D ...
- poj 1888 Crossword Answers 模拟题
Crossword Answers Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 869 Accepted: 405 D ...
- CodeForces - 427B (模拟题)
Prison Transfer Time Limit: 1000MS Memory Limit: 262144KB 64bit IO Format: %I64d & %I64u Sub ...
- sdut 2162:The Android University ACM Team Selection Contest(第二届山东省省赛原题,模拟题)
The Android University ACM Team Selection Contest Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里 ...
- 全国信息学奥林匹克联赛 ( NOIP2014) 复赛 模拟题 Day1 长乐一中
题目名称 正确答案 序列问题 长途旅行 英文名称 answer sequence travel 输入文件名 answer.in sequence.in travel.in 输出文件名 answer. ...
- UVALive 4222 Dance 模拟题
Dance 题目连接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&pag ...
- cdoj 25 点球大战(penalty) 模拟题
点球大战(penalty) Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/2 ...
- Educational Codeforces Round 2 A. Extract Numbers 模拟题
A. Extract Numbers Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/600/pr ...
- URAL 2046 A - The First Day at School 模拟题
A - The First Day at SchoolTime Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hust.edu.cn/vjudg ...
随机推荐
- 如何解压DMK固件
一.DMK固件 从罗克韦尔自动化下载的固件通常是以DMK为后缀名的文件: DMK文件无法直接使用,需要使用DMK Extraction Tool解压: 二.方法步骤 1. 如果从官网下载的固件文件后 ...
- css21规范学习
https://www.w3.org/TR/CSS22 1. An asterisk (*) indicates that the preceding type, word, or group occ ...
- sql注入--双查询报错注入原理探索
目录 双查询报错注入原理探索 part 1 场景复现 part 2 形成原因 part 3 报错原理 part 4 探索小结 双查询报错注入原理探索 上一篇讲了双查询报错查询注入,后又参考了一些博客, ...
- 分布式系列十二: Redis高级主题
持久化 Redis 支持持久化, 其持久化数据有两种方式. 两种可以同时使用. 如果同时使用, Reids 在重启时将使用 AOF 方式来还原数据. RDB 按照一定策略定时同步内存的数据到磁盘.文件 ...
- 读spring源码(二)-XmlBeanDefinitionReader-解析BeanDefinition
上次说到ApplicationContext加载BeanDefinition时会创建一个XmlBeanDefinitionReader,将XML解析.BeanDefinition加载委托给XmlBea ...
- 题解 P3246 【[HNOI2016]序列】
很久之前做过这道题,但是跑得贼慢,现在用了可以被卡成 n m 的笛卡尔树做法,发现跑得贼快[雾 noteskey 介绍一种复杂度错误然鹅在随机数据下跑得贼快的算法: 笛卡尔树 方法就是 \(O~ n\ ...
- linux 安装虚拟机
如果虚拟机创建不了就重启电脑 重启时 按下F2 出现后 第二个 往下 有个默认的 那个那个 打开虚拟机 选择第一个 然后是选择语言选择软件里面的 软件选择选择 基本网页服务器(右侧选择 python ...
- Jenkins的配置从节点中默认没有Launch agent via Java Web Start选项问题
Jenkins的配置从节点中默认没有Launch agent via Java Web Start,如下图所示,而这种启动方式在Windows上是最方便的. 如何设置才能让出来呢? 1:打开" ...
- js数据结构与算法——集合
<script> function Set(){ var items = {};//使用对象表示集合,因为js对象不允许一个键指向两个不同的值,保证集合里面的匀速唯一性 this.add ...
- ES2018新特性(译文)
原文链接:css-tricks.com 第9版ECMAScript标准于2018年6月发布,正式名称为ECMAScript 2018(简称ES2018).从ES2016开始,ECMAScript规范的 ...