总的来说,这套题的难度比较接近近些年来Day1的真实难度,认为非常值得一打

GotoAndPlay

题目大意

询问这个图上是否存在一种跳法,能跳到这个图上的每一个点

题目解析

犯了个低级错误,双向边忘记*2,最后两个点RE了

因为题目告知是“跳两次”,所以很容易想到将这个图分成“奇数点”和“偶数点”,那么所有“奇点“和所有“偶点”是能够独立相互到达的。

换句话来说,只要有一个点既属于“偶点“又属于”奇点”,那整个图都能相互到达了(这就是二分图)

因此我们先在原图做一遍DFS/BFS,标记初始标号

如果有一个点我们要对他进行标记两种不同标号,那整个图就完全可以到达了

如果假的一条边,连通了两个标记不一样的点,那“奇点”就可以到达“偶点”了,及那整个图就完全可以到达了

#include <cstdio>
#include <iostream>
#include <cstring>
using namespace std; #define qword long long
#define seta(x, y) memset(x, y, sizeof(x))
#define forn(i, n) for (int i = 1; i <= (int)(n); ++ i)
#define rep(i, s, t) for (int i = (int)(s); i <= (int)(t); ++ i) const int maxn = 4e5 + 10; inline void File() {
const string task = "GotoAndPlay";
freopen((task + ".in").data(), "r", stdin);
freopen((task + ".out").data(), "w", stdout);
} int n, m;
int to[maxn], head[maxn], next[maxn];
int color[maxn];
bool flag = false; int cnt = 0; inline void addEdge(int x, int y) {
to[++cnt] = y;
next[cnt] = head[x];
head[x] = cnt;
} inline void dfs(int x, int c) {
if (color[x] != -1 && color[x] != c) {flag = 1; return;}
color[x] = c;
for (int i = head[x]; i; i = next[i]) {
if (color[to[i]] == -1) dfs(to[i], (~c) & 1);
//else if (color[to[i]] == color[i]) flag = true;
}
} inline void query(int x) {
int a, b;
scanf("%d %d", &a, &b);
if (color[a] == color[b] || flag) {
printf("Yes\n"); return;
}
printf("No\n"); return;
} int main() {
//File();
scanf("%d %d", &n, &m);
int x, y;
forn(i, m) {
scanf("%d %d", &x, &y);
addEdge(x, y); addEdge(y, x);
}
forn(i, n) color[i] = -1; // Init
dfs(1, 0);
int p;
scanf("%d", &p);
forn(i, p) query(p);
return 0;
}

StopAllSounds

题目分析

一开始没有条理的乱搞,浪费了5分钟。。。

因为横只为2,所以我们可以分析出当前这只积木落下后最后的状态。

因为发现当前积木落下之后,下面所有的积木构成已经对后续没有影响,这满足了无后效性这一DP的基本条件

于是我们做一个dp,用 $ f[i][j] $ 表示现在最高的积木在 $ i $ 这个高度,最后一个状态是 $ j $ (这里我用1-6表示6中最终状态)

最后进行转移就行了

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std; #define qword long long
#define seta(x, y) memset(x, y, sizeof(x))
#define forn(i, n) for (int i = 1; i <= (int)(n); ++ i)
#define rep(i, s, t) for (int i = (int)(s); i <= (int)(t); ++ i) inline void File() {
const string task = "StopAllSounds";
freopen((task + ".in").data(), "r", stdin);
freopen((task + ".out").data(), "w", stdout);
} const int mod = 1e9 + 7; int n;
long long dp[1001000][7]; int main() {
File();
scanf("%d",&n);
memset(dp, 0, sizeof(dp));
forn(i, 6) dp[3][i] = 1;
dp[3][4] = 0; dp[2][4] = 1;
rep(i, 4, n) {
dp[i][1] = (dp[i-3][1] + dp[i-2][2] + dp[i-2][3] + dp[i-3][4] + dp[i-2][5] + dp[i-3][6]) % mod;
dp[i][2] = (dp[i-2][1] + dp[i-3][2] + dp[i-3][3] + dp[i-3][4] + dp[i-3][5] + dp[i-3][6]) % mod;
dp[i][3] = (dp[i-3][1] + dp[i-2][2] + dp[i-2][3] + dp[i-3][4] + dp[i-2][5] + dp[i-3][6]) % mod;
dp[i][4] = (dp[i-2][1] + dp[i-2][2] + dp[i-2][3] + dp[i-2][4] + dp[i-2][5] + dp[i-2][6]) % mod;
dp[i][5] = (dp[i-3][1] + dp[i-3][2] + dp[i-3][3] + dp[i-3][4] + dp[i-3][5] + dp[i-3][6]) % mod;
dp[i][6] = (dp[i-3][1] + dp[i-2][2] + dp[i-2][3] + dp[i-3][4] + dp[i-1][5] + dp[i-3][6]) % mod;
}
qword ans = 0;
rep(i, 2, n) forn(j, 6)
ans += dp[i][j] % mod;
printf("%lld", (ans + 1) % mod);
return 0;
}

UpdateAfterEvent

题目分析

这道题是这里面唯一一个达到了提高+/省选难度的题

首先思考如何将问题所求:期望的松鼠对数 转化为我们较为熟悉和擅长入手的东西。

大家能够发现,尽管可能大家最先想到的计算松鼠对数的方法,是根据树上的松鼠总数 $ x $,通过 $ x * (x - 1) / 2$ 来得到。但不妨考虑一下一个更一般的方法:

枚举一只松鼠,再枚举另一只松鼠,如果它们在同一棵树上则答案加一。

从这个方法中能够得到的启示是:松鼠对数这个量实际上是相对独立的,即与这两只松鼠之外的量并无直接的关系。

这样就避免了我们陷入一味考虑如何计算“松鼠期望总数”的错误方向了。

相似地,当我们计算期望时,也存在这样一个方法:

枚举一只松鼠 $ A $ ,再枚举另一只松鼠 $ B $ ,考虑它们同时存在在树i上的情况。

假设松鼠\(A\)在树i上的概率为 $ P(A, i) $ , 松鼠B在树i上的概率为 $ P(B, i) $

则它们同时存在于树i上的概率为 $ P(A, i) * P(B, i) $

而这一事件构成了“1对结束时在同一棵树上的松鼠”

因此对答案的贡献是 $ P(A, i) * P(B, i) * 1 $

我们只需要对于每一对松鼠枚举一下树 $ i $ ,然后对这些东西求和计入答案就可以了。

考虑如何计算 $ P(A,i) $ 。我们不妨假设 $ f(i, j) $ 为一只松鼠从点i出发,在点j停下的概率。

当 $ T = 0\(时,\) f [i][i] $ 均为1.0,每过一个单位时间时,考虑 $ f[i][j] $ 即松鼠当前在 $ j $ 时的概率

根据题中的描述向 $ j $的相邻点转移。

这样能够得到所有 $ T \le 30 $ 的分数

观察可知,每次的转移事实上都是一样的。于是我们可以使用矩阵乘法来优化这个转移过程。

时间复杂度 $ O(n^3logT) $ ,这部分有 $ 30 $ 的数据。

30%的部分分是给 $ n ^ 2 $ 计算期望的方法。直接枚举两个位置和终点的位置计算是 $ n ^ 3 $ 的,但是我们在枚举两个位置的时候,可以维护一下前缀和,累计的时候直接计算与前缀和的乘积。就可以将计算期望的过程优化到 $ n ^ 2 $ 了。

NOIP2016 “西湖边超萌小松鼠” 模拟赛的更多相关文章

  1. 小奇模拟赛9.13 by hzwer

    2015年9月13日NOIP模拟赛 by hzwer    (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...

  2. [模拟赛] StopAllSounds

    Description 小松鼠开心地在树之间跳跃着,突然她停了下来.因为眼前出现了一个 拿着专克超萌小松鼠的法宝----超萌游戏机的游客! 超萌游戏机之所以拥有这个名字,是因为它的屏幕是一个n × 2 ...

  3. [模拟赛] GotoAndPlay

    GotoAndPlay 10月3日,在杭州市西湖景区,一只小松鼠不停地接受一道道食物,花生. 玉米.饼干,可谓来者不拒,憨态可掬的模样吸引了众多围观者... Description 小松鼠终于吃撑了, ...

  4. 【20170521校内模拟赛】热爱生活的小Z

    学长FallDream所出的模拟赛,个人感觉题目难度还是比较适中的,难度在提高+左右,可能比较接近弱省省选,总体来讲试题考查范围较广,个人认为还是很不错的. 所有试题如无特殊声明,开启-O2优化,时限 ...

  5. Java 第十一届 蓝桥杯 省模拟赛 小明的城堡

    小明用积木搭了一个城堡. 为了方便,小明在搭的时候用的是一样大小的正方体积本,搭在了一个 n 行 m 列的方格图上,每个积木正好占据方格图的一个小方格. 当然,小明的城堡并不是平面的,而是立体的.小明 ...

  6. Java 第十一届 蓝桥杯 省模拟赛 小明植树(DFS)

    小明植树 题目 问题描述 小明和朋友们一起去郊外植树,他们带了一些在自己实验室精心研究出的小树苗. 小明和朋友们一共有 n 个人,他们经过精心挑选,在一块空地上每个人挑选了一个适合植树的位置,总共 n ...

  7. 串门赛: NOIP2016模拟赛——By Marvolo 丢脸记

    前几天liu_runda来机房颓废,顺便扔给我们一个网址,说这上面有模拟赛,让我们感兴趣的去打一打.一开始还是没打算去看一下的,但是听std说好多人都打,想了一下,还是打一打吧,打着玩,然后就丢脸了. ...

  8. 4.28 QBXT模拟赛

    NOIP2016提高组模拟赛 ——By wangyurzee7 中文题目名称 迷妹 膜拜 换数游戏 英文题目与子目录名 fans mod game 可执行文件名 fans mod game 输入文件名 ...

  9. 冲刺$\mathfrak{CSP-S}$集训模拟赛总结

    开坑.手懒并不想继续一场考试一篇文. 既没必要也没时间侧边栏的最新随笔题解反思相间也丑 而且最近越来越懒了竟然都不写题解了……开坑也是为了督促自己写题解. 并不想长篇大论.简要题解也得写啊QAQ. 目 ...

随机推荐

  1. 【APIO2016】Fireworks[DP 可并堆维护凸包优化]

    4585: [Apio2016]烟火表演 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 100  Solved: 66[Submit][Status] ...

  2. C++ 初始化函数的实现

    http://www.cppblog.com/xlshcn/archive/2007/11/21/37088.aspx

  3. windows下resin的配置部署与调试

    配置 从Resin官网(http://www.caucho.com)下载Resin解压后,启动Resin,运行resin根目录下的resin.exe文件,运行期间将出现下图所示的命令提示符窗口. 表示 ...

  4. log4j 设置将生成的日志进行gz压缩并删除过期日志

    1.准备jar  :log4j-1.2.17.jar,commons-logging-1.2.jar,这2个就可以了,其他关于日志的jar包就不要加进来了,在优先级上会有冲突. 2.定义一个类,继承R ...

  5. spring的AOP个人理解和使用

    1什么是AOP:AOP是面向切面编程,也就是说面向某个功能模块编程,典型的应用就是Spring的声明式事务, Spring的AOP事务解析: 在以前的事务管理是要融合在逻辑代码中的,在逻辑代码中决定事 ...

  6. c# 调用声音文件

    一.使用C#自带的SoundPlayer using System.Media; SoundPlayer sound = new SoundPlayer("声音.wav"); so ...

  7. 使用or展开进行sql优化(即sql语法union all代替or可以提高效率)

    问题: 这样一条sql应该怎么优化? select * from sys_user where user_code = 'zhangyong' or user_code in (select grp_ ...

  8. vue - 指令系统

    指令系统: 所谓指令系统,大家可以联想咱们的cmd命令行工具,只要我输入一条正确的指令,系统就开始干活了. 在vue中,指令系统,设置一些命令之后,来操作我们的数据属性,并展示到我们的DOM上. 1. ...

  9. Python开发【整理笔记】

    回顾笔记 学python半年,新知识不断填充,之前学的东西也忘的差不多,整理下笔记,把重点再加深下印象,算是读书拾遗吧.... 1.类继承.新式类.经典类 首先,新式类.经典类的概念只存在于Pytho ...

  10. 拨开障目的叶,一览CMDB庐山真面目

    人们往往用"一叶障目,不见泰山"来形容一个人被局部现象所迷惑,看不到事物发展的整体脉络,从而做出一些不是十分正确的决策.小编觉得对于运维何尝不是这样呢. 大多数企业资产配置维护的现 ...