【codeforces】【比赛题解】#869 CF Round #439 (Div.2)
良心赛,虽然我迟了半小时233333。
比赛链接:#869。
呃,CF的比赛都是有背景的……上次是《哈利波特》,这次是《物语》……
【A】巧妙的替换
题意:
Karen发现了石头剪刀布的决定性规律,看透了这个游戏的本质,使得石头剪刀布再无奥秘可言。
但是他的哥哥,Koyomi发明了一个新游戏:
他们先选定一个数\(n\),然后选出\(2n\)个互不相同的数,为\(x_{1},x_{2},\cdots,x_{n}\)和\(y_{1},y_{2},\cdots,y_{n}\)。
接下来他们数出无序数对\((i,j)\)的数量,使得\((i,j)\)满足\(x_{a}\hat{\;}y_{b}\)等于这\(2n\)个数中的某一个。
其中\(\hat{\;}\)符号代表按位异或。
如果这种数对的数量是偶数,则Karen赢,否则Koyomi赢。
判断谁会赢。
输入:
第一行一个数\(n,(1\leqslant n\leqslant2000)\)。
接下来一行n个数,表示\(x_{1},x_{2},\cdots,x_{n}(1\leq x_{i}\leq2\cdot10^6)\)。
接下来一行n个数,表示\(y_{1},y_{2},\cdots,y_{n}(1\leq y_{i}\leq2\cdot10^6)\)。
输出:
一行一个字符串"Karen"或"Koyomi",表示谁会赢,注意大小写。
题解:
把\(2n\)个数有没有出现过记下来,然后\(O(n^2)\)乱搞。
唯一的坑点是如\(2000000\hat{\;}97151=2097151\),大于2000000,所以数组要防止越界。
#include<cstdio>
int n,a[],y[],ans;
bool vis[];
int main(){
scanf("%d",&n);
for(int i=;i<=n;++i) scanf("%d",a+i), vis[a[i]]=;
for(int i=;i<=n;++i) scanf("%d",y+i), vis[y[i]]=;
for(int i=;i<=n;++i)
for(int j=;j<=n;++j)
if(vis[a[i]^y[j]]) ++ans;
if(ans&) puts("Koyomi");
else puts("Karen");
}
【B】不朽的神话
题意:
堆积药草和焚香,而后从其先祖的尘埃中重生,“凤凰涅槃”的故事被很多人所熟知。
凤凰有很长的生命周期,它每隔\(a!\)年就会轮回转世,这里\(a!\)表示\(a\)的阶乘。
Koyomi不关心这些,在他和更多的奇物搞的一团糟之前,他想知道在\(b!\)年中,凤凰会重生多少次,即\(\frac{b!}{a!}\)。
当\(a\leq b\)时,\(\frac{b!}{a!}\)总是整数。
答案可能会很大,所以Koyomi想知道答案的最后一位(十进制下)。
输入:
第一行,两个整数\(a,b(0\leq a\leq b\leq 10^{18})\)。
输出:
一个数字,表示答案的最后一位。
题解:
当\(b-a\geq5\)时,输出0。
#include<cstdio>
int main(){
long long a,b;
scanf("%I64d%I64d",&a,&b);
if(b-a>=) puts("");
else{
int last=;
for(long long c=a+;c<=b;++c) last=last*(c%);
printf("%d",last%);
}
return ;
}
【C】有趣的迷恋
题意:
齐心协力,我们可以以超乎想象的速度到达任何地方!现在,Fire Sisters——Karen和Tsukihi正在前往一个她们从未到达的地方——水中的小岛!
有三种不同类型的小岛,方便地,各自涂上了红,蓝,紫三色。每种颜色的小岛各自有\(a,b,c\)个。
这些小岛之间初始时互相分离。可以在小岛之间架桥,两个小岛间最多架一座桥。
但要满足:任意两个不同的颜色相同的小岛的最短距离要大于等于3(桥的长度为1)。
请你计算出不同的架桥方案有多少种。答案对998244353取模。
输入:
三个非负整数,\(a,b,c(0\leq a,b,c\leq5000)\)。
输出:
一个数,不同的架桥方案数对998244353取模的结果。
题解:
观察到一个颜色的小岛不能连向自己颜色的,也不能向同一颜色的小岛连去两条边。
也就是说,一个小岛能向另两种颜色的小岛连边,一种颜色最多连一条。
设\(f[i][j]\)表示两种颜色的小岛各有\(a,b\)个,它们之间互相连边,并满足条件的种数。
则答案等于\(f[a][b]\cdot f[b][c]\cdot f[c][a]\)。
而\(f[i][j]=f[i-1][j]+j\cdot f[i-1][j-1]\),这一点可以简单地推出。
我们使用动态规划算法求出所有可能的\(f[i][j]\)即可。
#include<cstdio>
const int Mod=;
long long f[][];
int main(){
for(int i=;i<=;++i) f[][i]=f[i][]=;
for(int i=;i<=;++i) for(int j=;j<=;++j) f[i][j]=(f[i-][j]+j*f[i-][j-])%Mod;
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
printf("%I64d",f[a][b]*f[b][c]%Mod*f[c][a]%Mod);
return ;
}
【D】
不会
【E】
二维树状数组可做。
【codeforces】【比赛题解】#869 CF Round #439 (Div.2)的更多相关文章
- Codeforces Round #439 (Div. 2)【A、B、C、E】
Codeforces Round #439 (Div. 2) codeforces 869 A. The Artful Expedient 看不透( #include<cstdio> in ...
- 竞赛题解 - CF Round #524 Div.2
CF Round #524 Div.2 - 竞赛题解 不容易CF有一场下午的比赛,开心的和一个神犇一起报了名 被虐爆--前两题水过去,第三题卡了好久,第四题毫无头绪QwQ Codeforces 传送门 ...
- CF Round #551 (Div. 2) D
CF Round #551 (Div. 2) D 链接 https://codeforces.com/contest/1153/problem/D 思路 不考虑赋值和贪心,考虑排名. 设\(dp_i\ ...
- CF Round #510 (Div. 2)
前言:没想到那么快就打了第二场,题目难度比CF Round #509 (Div. 2)这场要难些,不过我依旧菜,这场更是被\(D\)题卡了,最后\(C\)题都来不及敲了..最后才\(A\)了\(3\) ...
- CF Round #600 (Div 2) 解题报告(A~E)
CF Round #600 (Div 2) 解题报告(A~E) A:Single Push 采用差分的思想,让\(b-a=c\),然后观察\(c\)序列是不是一个满足要求的序列 #include< ...
- Codeforces Round #439 (Div. 2) 题解
题目链接 Round 439 div2 就做了两道题TAT 开场看C题就不会 然后想了好久才想到. 三种颜色挑出两种算方案数其实是独立的,于是就可以乘起来了. E题想了一会有了思路,然后YY出了一种 ...
- Codeforces Round #439 (Div. 2)
A. The Artful Expedient 题目链接:http://codeforces.com/contest/869/problem/A 题目意思:给你两个数列,各包含n个数,现在让你从上下两 ...
- Codeforces Round #439 (Div. 2) E. The Untended Antiquity
E. The Untended Antiquity 题目链接http://codeforces.com/contest/869/problem/E 解题心得: 1.1,x1,y1,x2,y2 以(x1 ...
- Codeforces Round #439 (Div. 2) C. The Intriguing Obsession
C. The Intriguing Obsession 题目链接http://codeforces.com/contest/869/problem/C 解题心得: 1.由于题目中限制了两个相同 ...
随机推荐
- C# 抽签小程序
设计背景 设置一个Excel名单表,对名单进行随机抽取. 设计思路 使用Timer定时器,运行定时器进行名单随机滚动,停止定时器获得抽签结果 相关技术 随机数 Excel读取/导出 XML文档读写 相 ...
- .net webapi创建接口
最近使用webapi做了一个用户数据库接口,方便其它网站接入验证用户,实现中解决出现的一些问题,做了一些记录, 1.返回显示为json数据 2.允许其他网站访问,刚开始没有设,在本地机测试时可以访问, ...
- BZOJ5254 FJWC2018红绿灯(线段树)
注意到一旦在某个路口被红灯逼停,剩下要走的时间是固定的.容易想到预处理出在每个路口被逼停后到达终点的最短时间,这样对于每个询问求出其最早在哪个路口停下就可以了.对于预处理,从下一个要停的路口倒推即可. ...
- 在java中为什么要把main方法定义为一个static方法?
我们知道,在C/C++当中,这个main方法并不是属于某一个类的,它是一个全局的方法,所以当我们执行的时候,c++编译器很容易的就能找到这个main方法,然而当我们执行一个java程序的时候,因为ja ...
- 【刷题】洛谷 P1519 穿越栅栏 Overfencing
题目描述 描述 农夫John在外面的田野上搭建了一个巨大的用栅栏围成的迷宫.幸运的是,他在迷宫的边界上留出了两段栅栏作为迷宫的出口.更幸运的是,他所建造的迷宫是一个“完美的”迷宫:即你能从迷宫中的任意 ...
- SpringBoot入门系列HelloWorld
根据咱们程序员学习的惯例,学习一门新技术都是从HelloWorld开始的. 感觉编程是一件非常富有意义的事情,程序员也是一群可爱的人,渴望被关怀和关注,因为我们总在和世界say Hi. 好了进入正题 ...
- Java开发23种设计模式
设计模式(Design Patterns) -- -- -- 可复用面向对象软件的基础 设计模式(Design Patterns)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结. ...
- Hbase—— rowkey 过滤器(rowfilter)
1.RowFilter 提取rowkey以01结尾数据Filter filter = new RowFilter(CompareFilter.CompareOp.EQUAL,new RegexStri ...
- 梯度下降法求解函数极大值-Matlab
目录 目录题目作答1. 建立函数文件ceshi.m2. 这是调用的命令,也可以写在.m文件里3. 输出结果题外话 题目 作答 本文使用MATLAB作答 1. 建立函数文件ceshi.m functio ...
- md5sum/opensll md5
http://m.blog.csdn.net/article/details?id=42041329 MD5算法常常被用来验证网络文件传输的完整性,防止文件被人篡改.MD5全称是报文摘要算法(Mess ...