前言

比赛链接:

Div.1 : http://47.110.12.131:9016/contest/13

Div.2 : http://47.110.12.131:9016/contest/12

Div.2——Charlotte

下面是 Div.2 的题解。

A. 我思及他人

对于 \(10\%\) 的数据,枚举 \(A,B,C\) 判断即可,时间复杂度 \(O(n^3)\)。

对于 \(30\%\) 的数据,枚举 \(A,B\) 判断 \(C\) 是否合法即可,时间复杂度 \(O(n^2)\)。

对于 \(50\%\) 的数据,枚举 \(C\) 计算它对答案的贡献即可,时间复杂度 \(O(n)\)。

对于 \(100\%\) 的数据,我们考虑把上面对 \(C\) 贡献的计算用数学方法搞成这样一个式子:(只用到了等差数列的求和公式)

\[ans=\sum_{i=1}^{R-2\times L+1}i=\frac{(R-2\times L+1)\cdot(R-2\times L+2)}{2}
\]

这样的时间复杂度为 \(O(1)\),即可通过本题。

if(R-L-L<0) printf("0\n");
else printf("%lld\n",(R-L-L+1)*(R-L-L+2)/2);

B. 恋情与火焰

这题应该算是道送分题——输出 No 有 \(60\) 分。(当然乱搞还可以得到更多的分)

但实际上正解也不算很难。

设 \(m\) 为 \(a_i\) 中的最小值,\(M\) 为 \(a_i\) 中的最大值,\(cnt\) 为 \(a_i\) 中 \(m\) 出现的次数。

  • 首先有一个显然的结论:若 \(M-m>1\),则不存在合法的构造方案。

  • 考虑另一种比较简单的结论:若 \(M-m=0\),则当且仅当 \(cnt=n-1\) 或 \(2\times cnt\leq n\) 时存在合法的构造方案。

事实上,我们会发现:\(n\) 个人中的颜色要么全都不同,要么就不存在某种颜色只出现了一次。

当颜色全都不同时,\(cnt=n-1\);当不存在某种颜色只出现了一次时,\(2\times cnt\leq n\)。

  • 最后来看这样一个结论:若 \(M-m=1\),则当且仅当 \(m<cnt\) 或 \(n-cnt<2\times (M-cnt)\) 时存在合法构造方案。

我们考虑 \(cnt\) 的本质意义:只出现一次的颜色数量。

对于一个颜色只出现一次的人来说,他能看到除自己以外所有只出现一次的颜色,有 \(cnt-1\) 种。

同时他还能看到至少一种出现多次的颜色,所以他至少应该看到 \(cnt\) 种颜色。

于是合法的构造要满足 \(m\geq cnt\)。

类似地,对于一个颜色出现多次的人来说,他可以看到当前的所有颜色,所以 \(M\) 是颜色总数。

那么 \(M-cnt\) 就是出现多次颜色的数量。

而出现多次的颜色至少要有两个,那么此时就需要满足 \(n-cnt\geq 2\times (M-cnt)\) 才有合法方案。

根据上述三个结论便可得到正解。

#include<bits/stdc++.h>
#define Re register
using namespace std; const int N=100005;
int n,a[N];
int cnt,Max,Min=0x3f3f3f3f; int main()
{
scanf("%d",&n);
for(Re int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
Max=max(Max,a[i]);
Min=min(Min,a[i]);
}
for(Re int i=1;i<=n;i++)
{
if(a[i]==Min)
{
cnt++;
}
}
if(Max-Min>1) return 0*puts("No");
if(Max==Min)
{
if(Min==n-1||2*Min<=n) return 0*puts("Yes");
else return 0*puts("No");
}
if(Min<cnt||n+cnt<2*Max) return 0*puts("No");
return 0*puts("Yes");
}

C. 未曾留意的幸福

取 \(x=\left(\prod\limits_{i=1}^{n}a_i\right)-1\) 可得 \(f(x)=\left(\sum\limits_{i=1}^{n}a_i\right)-n\)。

这样 \(O(n)\) 计算即可。

scanf("%d",&n);
for(Re int i=1;i<=n;i++)
{
scanf("%d",&a);
ans+=a;
}
printf("%d",ans-n);

D. 不在此处的世界

考虑 \(\operatorname{lcm}(x,y)\) 可能取到的最小值。

实际上,取 \(x=L,y=2\times L\) 得到 \(\operatorname{lcm}(x,y)=2\times L\) 为最小值。

这样 \(O(1)\) 计算即可。

if(r<2*l) puts("-1 -1");
else printf("%d %d\n",l,2*l);

E. 你我的约定

把每个 pair 写作 \((a_i,b_i)\)、\((-a_i,-b_i)\) 的形式。

那个符号的组合意义就变成是 \((a_i,b_i)\) 到 \((-a_j,-b_j)\) 的折路径个数。

于是就可以在平面上 DP 来一起统计:设 \(f_{i,j}\) 表示 \((i,j)\) 到它左下角的点的路径总数。

那么有 \(f_{i,j}=f_{i-1,j}+f_{i,j-1}+cnt_{i,j}\),搞定。

Div.1——某科学的超电磁炮

下面是 Div.1 的题解。

A. RAILGUN

同 Div.2 的 A 题。

B. 御坂妹妹

答案就是两倍总边长减去树的直径。

这个比较显然,你手模一下,发现整棵树绝大多数边都需要遍历两遍,除了其中一条路径,那么当然减去直径最合算。

C. 白井黑子

同 Div.2 的 B 题。

D. 上条当麻

答案为:\(P^{(n-1)^2}\),因为你枚举左上的 \(n-1\) 行和 \(n-1\) 列的结果,有这么多种。

于是你可以求得 \(A_{i,n}=P\cdot(N-1)-\sum_{j=1}^nA_{i,j}\),\(A_{n,i}\) 也同理。

对于 \(A_{n,n}\),你会惊奇地发现没有冲突!

注意:\(C\) 是没有用的,实现的时候,模数只能对 \(998244353-1\) 取模。

inline void solve()
{
long long n, c, m; cin >>n >>c >>m;
cout << qpow(m % 998244353, (n - 1) % 998244352 * ((n - 1) % 998244352) % 998244352) << endl;
}

E. 信仰不灭

这个是 SG 函数的模板应用,如果不会的话可以看一下 SG 函数的 oi-wiki,代码如下:

#include <bits/stdc++.h>

using namespace std; typedef long long ll; const int maxn = 5e6 + 1e2;

int n, cnt, SG[maxn]; unordered_map<ll, int> id;

inline ll get(int x, int y) { return x * 100000ll + y; }

int DFS(int x, int y)
{
//cerr << x << ' ' << y << ' ' << cnt << endl;
if (x + y >= n) return 0; int u, v;
if (u = id[get(x, y)]) return SG[u]; u = id[get(x, y)] = ++cnt;
v = DFS(1, x + y); if (!v) SG[u] = 1;
v = DFS(x * 2, y); if (!v) SG[u] = 1;
v = DFS(x * 3, y); if (!v) SG[u] = 1; return SG[u];
} extern "C" int _opt(int nn, int x, int y)
{
n = nn, DFS(1, 0);
if (!SG[id[get(1, x + y)]]) return 1;
if (!SG[id[get(x * 2, y)]]) return 2;
if (!SG[id[get(x * 3, y)]]) return 3;
return -1;
} int main()
{
int n, a, b; cin >> n >>a >>b;
cout << _opt(n, a, b) << endl;
}

YAOI Round #5 题解的更多相关文章

  1. YAOI Round #7 题解

    前言 比赛链接: Div.1 : http://47.110.12.131:9016/contest/16 Div.2 : http://47.110.12.131:9016/contest/15 D ...

  2. YAOI Round #3 题解

    前言 比赛链接: Div.1 : http://47.110.12.131:9016/contest/7 Div.2 : http://47.110.12.131:9016/contest/8 Div ...

  3. YAOI Round #1 题解

    前言 比赛网址:http://47.110.12.131:9016/contest/3 总体来说,这次比赛是有一定区分度的, \(\text{ACM}\) 赛制也挺有意思的. 题解 A. 云之彼端,约 ...

  4. Codeforces Round #556 题解

    Codeforces Round #556 题解 Div.2 A Stock Arbitraging 傻逼题 Div.2 B Tiling Challenge 傻逼题 Div.1 A Prefix S ...

  5. LibreOJ β Round #2 题解

    LibreOJ β Round #2 题解 模拟只会猜题意 题目: 给定一个长为 \(n\) 的序列,有 \(m\) 次询问,每次问所有长度大于 \(x\) 的区间的元素和的最大值. \(1 \leq ...

  6. Codeforces Round #569 题解

    Codeforces Round #569 题解 CF1179A Valeriy and Deque 有一个双端队列,每次取队首两个值,将较小值移动到队尾,较大值位置不变.多组询问求第\(m\)次操作 ...

  7. Codeforces Round #557 题解【更完了】

    Codeforces Round #557 题解 掉分快乐 CF1161A Hide and Seek Alice和Bob在玩捉♂迷♂藏,有\(n\)个格子,Bob会检查\(k\)次,第\(i\)次检 ...

  8. CFEducational Codeforces Round 66题解报告

    CFEducational Codeforces Round 66题解报告 感觉丧失了唯一一次能在CF上超过wqy的机会QAQ A 不管 B 不能直接累计乘法打\(tag\),要直接跳 C 考虑二分第 ...

  9. Google kickstart 2022 Round A题解

    Speed Typing 题意概述 给出两个字符串I和P,问能否通过删除P中若干个字符得到I?如果能的话,需要删除字符的个数是多少? 数据规模 \[1≤|I|,|P|≤10^5 \] 双指针 设置两个 ...

随机推荐

  1. 面试侃集合 | SynchronousQueue非公平模式篇

    面试官:好了,你也休息了十分钟了,咱们接着往下聊聊SynchronousQueue的非公平模式吧. Hydra:好的,有了前面公平模式的基础,非公平模式理解起来就非常简单了.公平模式下,Synchro ...

  2. 功率半导体碳化硅(SiC)技术

    功率半导体碳化硅(SiC)技术 Silicon Carbide Adoption Enters Next Phase 碳化硅(SiC)技术的需求继续增长,这种技术可以最大限度地提高当今电力系统的效率, ...

  3. Django(55)GenericAPIView源码分析

    源码分析 GenericAPIView继承自APIView,也就是在APIView基础上再做了一层封装,源码如下: class GenericAPIView(views.APIView): query ...

  4. 解决:django.core.exceptions.ImproperlyConfigured: Requested setting INSTALLED_APPS, but settings are not 的方法

    错误类型: 该错误是在在创建Django工程时出现遇到的错误 完整报错信息:(博文标题输入长度有限制) django.core.exceptions.ImproperlyConfigured: Req ...

  5. Jmeter-逻辑控制器If Controller的实例运用

    一.If Controller概述 Expression (must evaluate to true or false) :表达式(值必须是true或false),也就是说,在右边文本框中输入的条件 ...

  6. robotframework用户关键字创建过程

    robotframework是一个关键字驱动框架,核心在于关键字的应用.系统本身通过各种库自带了大量关键字,同时支持用户自定义关键字.关键字可以简单理解为各种处理数据的方法. 关键字区别与用户参数. ...

  7. LuatOS | 全新在线模拟器,随时随地发挥创意

    LuatOS --运行在嵌入式硬件的实时操作系统,开启全新物联网生态. 聚焦嵌入式应用生态,内置功能可支持绝大多数物联网应用场景.深度整合Lua语言,只需少量内存和Flash空间就能运行.不局限于合宙 ...

  8. 【Java】equals 和 == 的区别

    之前有在 Java字符串比较(3种方法)以及对比 C++ 时的注意项 中写过一点关于 equals()与==的比较,但最近的Java考试复习过程中发现有部分情况没涉及到,故重新学习一下 在编写代码的时 ...

  9. [Abp vNext 源码分析] - 20. 电子邮件与短信支持

    一.简介 ABP vNext 使用 Volo.Abp.Sms 包和 Volo.Abp.Emailing 包将短信和电子邮件作为基础设施进行了抽象,开发人员仅需要在使用的时候注入 ISmsSender ...

  10. React 并发功能体验-前端的并发模式已经到来。

    React 是一个开源 JavaScript 库,开发人员使用它来创建基于 Web 和移动的应用程序,并且支持构建交互式用户界面和 UI 组件.React 是由 Facebook 软件工程师 Jord ...