2017CodeM复赛
A、配对游戏(loj6191)
题目:
分析:
g[i][j]表示前i个位置尽可能合并,合并到最后右边剩下j个>,这样情况的概率
那么g[i][j]=0.5*g[i-1][j-1]+0.5*g[i-1][j+1]
我们能不能根据概率来求期望呢?
emmmmm...有点困难,因为我们只知道每种情况下右边剩余>的个数,却不知道左边剩余<的个数
其实这两个是对称的,所以结果*2就行了
如果没发现这个怎么办呢?那就老老实实设期望
f[i][j]表示在g[i][j]描述背景下剩余个数的期望
那么f[i][j]=0.5*(g[i-1][j-1]+1*f[i-1][j-1])+0.5*(g[i-1][j+1]-1*f[i-1][j+1])
时间复杂度O(n^2)
B、城市网络(loj6192)
题目:
分析:
直观想法是要在树上维护一个可撤销的单调栈……但好像不太好弄……换思路
首先可以把询问(u,v,c)转换成u点下挂个点,这个点的点权是c
现在关键问题就是如何快速找到树上每个点的father,这个father是点到根路径上最近的比它大的那个点
可以这样搞,倍增求出fa[i][j]表示i的j级父亲,mx[i][j]表示i向上到j级父亲下面这段点的最大点权
那么就可以根据mx倍增走出每个点的最近父亲,然后对于新的父亲进行倍增
对于每个询问根据深度倍增就行了
时间复杂度O(nlogn)
C、神秘代号(loj6193)
题目:
分析:
n个点n条边构成的是一个基环外向树,那个环所表示的模方程正好首位相接,可以解出一个未知数xi的值
然后发现如果确定了一个点的值,那么其它点的值都可以通过bfs得到,并且不会冲突
注意可能有多个基环外向树
D、排列(loj6194)
题目:
分析:
我们通过saved的更新过程来考察所有排列
设saved的值按顺序依次是p[1],p[2]....,p[k]
我们首先来考察给定一个顺序p[1],p[2]....p[k]下,符合的排列有多少个
考虑相邻的p[i]与p[i+1],我们发现p[i]右上方的所有点必须排在p[i+1]后面
于是我们设a[i]表示点p[i]右上方有多少个点(包括自己)
那么符合条件的排列数有多少呢?我们先考虑简单情况,只有两个p[1] p[2]
那么问题相当于求n的带限制排列数,限制是有x-1个数字必须排在数字p[1]之后
考虑这x个数顺序完全固定,那么根据经典结论方案数是n!/x!
但实际上这x个数的后x-1个数是可以排列的 ,所以方案数是n!/x!*(x-1)!=n!/x
那么推广到一般形式,即k>2,发现集合是嵌套的
所以对于一个给定的p[1]....p[k],方案数就是n!/(a[1]*a[2]*a[3]...*a[k])
于是我们可以得出一个O(n^2)的递推算法
f[i]表示以点i为最后一个saved的方案数
那么f[i]=Σf[j]*inv(a[j]) (j在i的左下方)
很容易发现这个如何优化,这个本质就是求左下方的和
于是第一维排序,第二维树状数组
此题也很容易推广到高维,cdq分治即可
2017CodeM复赛的更多相关文章
- 05:统计单词数【NOIP2011复赛普及组第二题】
05:统计单词数 总时间限制: 1000ms 内存限制: 65536kB 描述 一般的文本编辑器都有查找单词的功能,该功能可以快速定位特定单词在文章中的位置,有的还能统计出特定单词在文章中出现的次 ...
- BOP 2016 复赛题目
复赛采用团队赛的形式,基于Azure云计算平台在实际大数据的基础上展开前沿课题的较量. 在编程之美挑战赛复赛中,选手需要通过组队共同完成复赛题,考查选手编程能力的同时,也考验选手的团队协作能力.选手点 ...
- CCF关于NOIP2014复赛报名的通知
CCF关于NOIP2014复赛报名的通知 CCF NOIP2014复赛全部实行网上注册.报名.未通过网上报名的选手将不具备参赛和申诉资格. 系统注册须知: NOIP2014复赛注册时间:2014年 ...
- NOIP2013,复赛及同步赛,报名及比赛,专题页面
本通知的对象仅仅是福州第十九中学的学生 所有参加复赛以及同步赛的选手,请务必要仔细阅读:<关于CCF NOIP2013复赛有关事宜的通知>,里面有比赛的时间.地点.以及比赛费用的说明. 参 ...
- 纪录参加noip2015(pj+tg)复赛
作为一个既参加了pj又参加了tg的初三蒟蒻,本次复赛不得不算一次很happy的事(可以不做周末作业,可以逃掉小班培训) 昨年参加pj的时候,一题眼瞎,二题作死,只有三题蒙了一点分,简直差到一种境界. ...
- CCF NOIP2015复赛获奖分数线及名额分配办法
CCF NOIP2015复赛获奖分数线及名额分配办法 中国计算机学会CCF NOI竞赛委员会.科学委员 ...
- hdu 4542 数论 + 约数个数相关 腾讯编程马拉松复赛
题目:http://acm.hdu.edu.cn/showproblem.php?pid=4542 小明系列故事--未知剩余系 Time Limit: 500/200 MS (Java/Others) ...
- 2017"百度之星"程序设计大赛 - 复赛1005&&HDU 6148 Valley Numer【数位dp】
Valley Numer Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
- 2017"百度之星"程序设计大赛 - 复赛1003&&HDU 6146 Pokémon GO【数学,递推,dp】
Pokémon GO Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
随机推荐
- windows session logoff时进行处理动作
目标:Windows session logoff时得到通知,进行一些记录/清理工作 测试平台: win7 x64 logoff时系统会发送WM_ENDSESSION消息,如果某个应用对这个消息的处理 ...
- upupw nginx服务器 rewrite设置
最近开始尝试使用upupw的Nginx套件做开发,感觉还挺不错的,也遇到了一些问题,决定在这里记录一下,同时也希望可以帮助到一些人. 用习惯了Apache,改用Nginx之后会有些不适应,但是咬咬牙就 ...
- PHP一句话后门过狗姿势万千之理论篇
写在前面: 过狗相关的资料网上也是有很多,所以在我接下来的文章中,可能观点或者举例可能会与网上部分雷同,或者表述不够全面. 但是我只能说,我所传达给大家的信息,是我目前所掌握或者了解的,不能保证所有人 ...
- 7-Java-C(骰子游戏)
题目描述: 我们来玩一个游戏. 同时掷出3个普通骰子(6个面上的数字分别是1~6). 如果其中一个骰子上的数字等于另外两个的和,你就赢了. 下面的程序计算出你能获胜的精确概率(以既约分数表示) pub ...
- OSI七层模型和TCP/IP五层模型详解
OSI是一个开放性的通信系统互连参考模型,他是一个定义得非常好的协议规范.OSI模型有7层结构,每层都可以有几个子层. OSI的7层从上到下分别是 7 应用层 6 表示层 5 会话层 4 传输层 3 ...
- QT+信号和槽函数_自定义槽函数_一个信号对应多个槽函数
以下的代码里面有自定义槽函数的内容,同时也有信号实现的函数: #ifndef MAINWIDGET_H #define MAINWIDGET_H #include <QWidget> #i ...
- 最短路 || POJ 2387 Til the Cows Come Home
从点N到1的最短路 *记得无向图两个方向都要建边就好了…… 以及多组数据= = #include <iostream> #include <cstdio> #include & ...
- C++构造函数(复制构造函数)、析构函数
注:若类中没有显示的写如下函数,编译会自动生成:默认复制构造函数.默认赋值构造函数(浅拷贝).默认=运算符重载函数(浅拷贝).析构函数: 1.默认构造函数(默认值)构造函数的作用:初始化对象的数据成员 ...
- JavaSE-29 Java8的Lambda表达式
概念说明 Lambda表达式是Java8提供的新特性,支持将代码块作为方法的参数. Lambda表达式支持使用简洁的代码创建只有一个方法的接口(函数式接口). 只包含一个方法的接口也称为函数式接口. ...
- WebGL 绘制Line的bug(二)
上一篇文章简单介绍了WebGL绘制Line的bug,不少朋友给我发了私信,看来这个问题大家都遇上过哈.今天这篇文章会讲述解决这个问题的work around. 基本思路 上一篇文章结尾简单提了下解决的 ...