总体来说很有一定区分度的(主要分为 4 题、2 题、1 题几档),ACM 赛制也挺有意思的,征求一下大家对这场比赛的意见吧,可以在这个帖子下回复,我都会看的。

简要题解:(

A. 云之彼端,约定的地方

解法:

本题是拓扑学中的欧拉公式的结论题。

我们发现 \(V=E-F+2\) ,于是便得到了答案。

代码:

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. int main()
  4. {
  5. int e,f;
  6. scanf("%d%d",&e,&f);
  7. printf("%d",e-f+2);
  8. return 0;
  9. }

B. 秒速 5 厘米

考点: 欧几里得法,裴蜀定理,简单数论/构造。近年来考试对数论的考察(如17、18年)都有所加深,今年更是考了一道构造题。

题解: 要使所有的数清零,也就是要使方程 \(len1 \times x + len2 \times y + len3 \times z + X = 0\) 这个方程一定有解。联想到裴蜀定理:\(ax+by=c\)有解当且仅当 \(\gcd(x,y) | c\),当 \(a\)、\(b\) 互质的时候这个方程一定有解。所以我们第一次操作修改 \(1\)$n$,第二次修改$1$\(n-1\),第三次修改\(n\)。由于 \(n\) 和 \(n-1\) 互质,前两次一定存在方法使两次之和加上原数等于 \(0\),而最后一次操作能使最后一个数清零。

具体构造方案就变成了解方程 \(nx + (n-1)y = C\) 的任意一组解,不管是交给小学奥数还是交给拓展欧几里得都是可以的。

这题的构造其实不难想到,当然观察样例也可以发现,可以说观察样例是极其重要的能力。

标程: (来自 liyiming,我自己是用拓欧写的,放这个比较友好。)

  1. int main() {
  2. cin >> n;
  3. for (int i = 1; i <= n; i++) cin >> a[i];
  4. cout << 1 << " " << n - 1 << endl;
  5. cout << a[1] * (n - 1);
  6. for (int i = 2; i <= n - 1; i++) cout << " " << a[i] * (n - 1);
  7. cout << endl;
  8. cout << 1 << " " << n << endl;
  9. for (int i = 1; i <= n - 1; i++) cout << -a[i] * n << " ";
  10. cout << 0 << endl;
  11. cout << n << " " << n << endl;
  12. cout << -a[n];
  13. cout << endl;
  14. return 0;
  15. }

C. 追逐繁星的孩子

解法:

对于这棵树,从 \(1\) 号节点开始进行一次 \(\text{dfs}\) ,并在过程中计算经过该点的概率即可。

当然,如果当前概率已经不合法,则可以剪枝优化。

代码:

  1. #include <bits/stdc++.h>
  2. #define Re register
  3. using namespace std;
  4. const int maxn=500005;
  5. vector<int> T[maxn],E[maxn];
  6. int n,q,cnt;
  7. void dfs(int x,int fa,long double p)
  8. {
  9. if(p*100<q) return;
  10. cnt++;
  11. for(Re int i=0;i<T[x].size();i++)
  12. {
  13. if(T[x][i]==fa) continue;
  14. dfs(T[x][i],x,p*E[x][i]/100);
  15. }
  16. }
  17. int main()
  18. {
  19. scanf("%d%d",&n,&q);
  20. for(Re int i=1;i<n;i++)
  21. {
  22. int u,v,p;
  23. scanf("%d%d%d",&u,&v,&p);
  24. T[u].push_back(v);
  25. T[v].push_back(u);
  26. E[u].push_back(p);
  27. E[v].push_back(p);
  28. }
  29. dfs(1,1,1.0);
  30. printf("%d",cnt);
  31. return 0;
  32. }

D. 言叶之庭

标程:

  1. int n; cin >>n;
  2. for (int i = n - 1; i >= 0; i--)
  3. {
  4. f[i] = f[i+1] + (double)n / ((double)n - i);
  5. g[i] = g[i+1] + (double)i / ((double)n - i) * f[i]+ f[i+1] + (double)n / ((double)n - i);
  6. }
  7. printf("%.2lf",g[0]);

考点: 期望相关知识,可以说期望是一个大难点,如何逾越它是个重要的问题。

题解: 这题的期望还是很巧妙的。

设 \(f_{i}\) 表示已经买到了 \(i\) 张不同的邮票的期望步数,\(g_{i}\) 表示表示已经买到了 \(i\) 张不同的邮票的期望花费;\(h_{i}\) 表示已经买到了 \(i\) 张不同的邮票、想买下剩下邮票的期望步数,\(y_{i}\) 表示表示已经买到了 \(i\) 张不同的邮票、想买下剩下邮票的期望花费。

我们可以得到一些好玩的式子们,有一些是对的,有一些是错的:

\[f_i = f_{i-1} + \frac{n}{n-i+1}
\]

这个式子是对的,为什么呢?我抽到新邮票的概率是 \(\frac{n-i+1}{n}\),那么抽到新邮票的期望次数就是 \(\frac{n}{n-i+1}\)。上述式子甚至可以写成 $ f_n = \sum\limits { \frac{1}{i} } $。

\[g_n = \frac{f_n(f_n+1)}{2}
\]

这个式子显然是错的。为什么呢?有两种解释方法,一是每种 \(f_n\) 的取值的贡献不是一样的,不满足线性性;也可以看做是 \(\mathbb{E}(x^2)\) 作为不独立的两个变量相乘,不具有线性性。

\[g_i = g_{i-1} + f_i \times \frac{n}{n-i+1}
\]

这个式子又是对的了,这个成立就能得到一些很好玩的式子,比如 $ f_{n} = \sum\limits_{i=1}^{n}(\frac{n}{i} \sum\limits_{j=1}^{i}(\frac{n}{i})) $。

\[h_i = \frac{i}{n}(h_i + 1) + \frac{n-i}{n}(h_{i+1} + 1)
\]

这个来源于分类讨论,两种情况分别讨论一下,移项一下就能得到递推式。

\[y_i = \frac{i}{n}(h_i+y_i+1) + \frac{n-i}{n}(h_{i+1}+y_i+1)
\]

和上面的方程的来源是一样的,但是需要用到费用提前计算——\(h_i+1\) 的含义是替后面的提前加上。但这个式子还是有一些难以解释通的地方,为什么递归下去后每次提前计算的贡献是相同的?那不是成了平行四边形吗?这个方法使得期望满足了线性性——竖着我统计没有线性性,横过来看就能巧妙地去掉乘积项,就拥有了线性性。

更为不严谨的方程: 设买了 \(x\) 次邮票,答案就是 \(\frac{x+x^2}{2}\)。设 \(w_i\) 表示已经买到了 \(i\) 种邮票、要买剩下的的邮票的次数平方的期望(注意和期望的平方的区别),那么可以得到

\[w_i = \frac{i}{n}(w_i + 2h_i + 1) + \frac{n-i}{n}(w_{i+1} + 2h_{i+1} + 1)
\]

于是答案就是 \(\frac{h_0 + w_0}{2}\)。但是——这么做是有问题的——因为默认了平方的期望等于期望的平方!但是,他居然是对的!错的做法能过,说明过的做法都是错的,细思极恐啊!

E. 你的名字

考点: 组合数学,计数问题。计数问题是福建省选的黄金考点,六题能出四道计数。

题解: 使用 Burnside 引理(\(cnt = \frac{1}{|G|}\sum\limits \chi (x)\))或者简单的容斥可得 \(ans=\frac{2 \times 2^{\frac{n^2}{4}} + 2^{\frac{n^2}{2}} + 2^{n^2}}{4}\),下面讨论如何计算这个值。

2 的那么多次方可以使用快速幂计算;由于指数远远超出了 long long 范畴,所以考虑怎么把指数变小。由费马小定理得 \(2^{p-1} \equiv 1 (mod p)\),所以 \(2^{k} \equiv 2^{k mod (p-1)} (mod p)\);所以只需计算 \(n^2 mod (p-1)\);这个东西远远超过 long long,要计算它的取模,可以使用这个小技巧:

  1. inline ll ksc(ll x, ll y, ll p){
  2. ll z = (ld)x / p * y;
  3. ll res=(ull)x * y - (ull)z *p ;
  4. return (res + p) % p;
  5. }

标程:

  1. cout << (2 * 1ll * qpow(2, ksc(n / 2, n / 2, mod - 1)) +
  2. qpow(2, ksc(n / 2, n, mod - 1)) + qpow(2, ksc(n, n, mod - 1)))
  3. % mod * 1ll * inv4 % mod << endl;

F. 天气之子

考点: 计数问题,树论,树论是 noip / CSP 的几乎最重要的考点。

题解: 这种方法叫做 贡献 法,考虑一个连通块在那些 \([l,r]\) 中出现过;那么我们需要取其中一个点作为这个连通块的代表,那么我就取深度最浅的那个点作为连通块的代表结点。于是我们枚举每个结点作为连通块的最浅结点,显然它能作为最浅结点当且仅当它的父节点没有被取到,当它的父节点被取到时,它就不是最浅借点,也可以认为这个连通块它不存在。于是我们快乐地得到如下代码:

标程:

  1. u64 ans = 0;
  2. for (int i = 2; i <= n; i++)
  3. {
  4. if (fat[i] < i)
  5. {
  6. ans += (i - fat[i]) * 1ll * (n - i + 1);
  7. }
  8. else
  9. {
  10. ans += (fat[i] - i) * 1ll * i ;
  11. }
  12. }

YAOI Round #1 (Div.2) 题解的更多相关文章

  1. Codeforces Round #182 (Div. 1)题解【ABCD】

    Codeforces Round #182 (Div. 1)题解 A题:Yaroslav and Sequence1 题意: 给你\(2*n+1\)个元素,你每次可以进行无数种操作,每次操作必须选择其 ...

  2. 喵哈哈村的魔法考试 Round #2 (Div.2) 题解

    喵哈哈村的魔法考试 Round #2 (Div.2) 题解 A.喵哈哈村的战争 题解: 这道题就是for一遍,统计每个村子的战斗力的和,然后统计哪个村子的战斗力和大一点就好了. 唯一的坑点,就是这道题 ...

  3. 喵哈哈村的魔法考试 Round #1 (Div.2) 题解

    喵哈哈村的魔法考试 Round #1 (Div.2) 题解 特别感谢出题人,qscqesze. 也特别感谢测题人Xiper和CS_LYJ1997. 没有他们的付出,就不会有这场比赛. A 喵哈哈村的魔 ...

  4. Codeforces Round #608 (Div. 2) 题解

    目录 Codeforces Round #608 (Div. 2) 题解 前言 A. Suits 题意 做法 程序 B. Blocks 题意 做法 程序 C. Shawarma Tent 题意 做法 ...

  5. Codeforces Round #525 (Div. 2)题解

    Codeforces Round #525 (Div. 2)题解 题解 CF1088A [Ehab and another construction problem] 依据题意枚举即可 # inclu ...

  6. Codeforces Round #528 (Div. 2)题解

    Codeforces Round #528 (Div. 2)题解 A. Right-Left Cipher 很明显这道题按题意逆序解码即可 Code: # include <bits/stdc+ ...

  7. Codeforces Round #466 (Div. 2) 题解940A 940B 940C 940D 940E 940F

    Codeforces Round #466 (Div. 2) 题解 A.Points on the line 题目大意: 给你一个数列,定义数列的权值为最大值减去最小值,问最少删除几个数,使得数列的权 ...

  8. Codeforces Round #677 (Div. 3) 题解

    Codeforces Round #677 (Div. 3) 题解 A. Boring Apartments 题目 题解 简单签到题,直接数,小于这个数的\(+10\). 代码 #include &l ...

  9. Codeforces Round #665 (Div. 2) 题解

    Codeforces Round #665 (Div. 2) 题解 写得有点晚了,估计都官方题解看完切掉了,没人看我的了qaq. 目录 Codeforces Round #665 (Div. 2) 题 ...

随机推荐

  1. 用css写三角形

    html部分 <div class="triangle></div> css部分 .triangle{ width:0; height:0; overflow:hid ...

  2. Egg.js学习与实战系列 · 文件上传配置

    在使用Egg.js搭建文件上传服务时,遇到了几个一般新手都会遇到的坑. 经查阅官方文档,Egg框架中默认使用egg-multipart插件进行文件上传,所以上传文件前需要做相关的配置. 上传文件提示: ...

  3. UltraSoft - Beta - Postmortem事后分析

    UltraSoft - Beta - PostMORTEM 设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 解决的问题和定义都在[软软软]功能规格说明书 ...

  4. [软软软]技术博客-Commitizen优化git commit

    工具介绍 commitizen/cz-cli是一个规范git commit的工具,使用它代替git commit能够方便有效地写好提交的log,使得团队项目的版本信息更清晰. 安装 (全局安装) np ...

  5. Machine learning(2-Linear regression with one variable )

    1.Model representation Our Training Set [训练集]: We will start with this ''Housing price prediction'' ...

  6. Shooting Bricks题解

    题目传送门 以后我绝对不会一直磕着一道题磕几个小时了...感觉还是自己节奏出了问题,不知为啥感觉有点小慌... 算了,其实再回头仔细看一下这个题dp的思路还是比较好想出来的,打代码之前一定要做好足够的 ...

  7. 51nod_1006 最长公共子序列,输出路径【DP】

    题意: 给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这两个 ...

  8. hdu 2086 A1 = ? (公式推导)

    有如下方程:Ai = (Ai-1 + Ai+1)/2 - Ci (i = 1, 2, 3, .... n).若给出A0, An+1, 和 C1, C2, .....Cn.请编程计算A1 = ? Inp ...

  9. 关于ENSP错误代码的常见问题

    1.最适合ensp运行的环境是win7,在win7上运行基本不会出什么大问题(ensp370+virtualbox4.2.8) 2.如果需要重新安装,最好把旧版本清除干净,ensp+virtualbo ...

  10. Redis去重方法

    目录 1.基于 set 2.基于 bit 3.基于 HyperLogLog 4. 基于bloomfilter 这篇文章主要介绍了Redis实现唯一计数的3种方法分享,本文讲解了基于SET.基于 bit ...