这次是Div.1+Div.2,所以有7题。

因为时间较早,而且正好赶上训练,所以机房开黑做。

然而我们都只做了3题。:(。

链接

【A】声控解锁

题意:

Arkady的宠物狗Mu-mu有一只手机。它需要朝这个手机吠一个英文单词密码(两个字符长),手机才能解锁。

Mu-mu的仇敌,Kashtanka想要解锁Mu-mu的手机,但是它只会说一些两个字符长的英文单词。

它想要用某种顺序吠出若干个英文单词,使得手机能解锁。告诉Kashtanka它有没有可能做到这一点。

输入:

第一行一个两个字符长的字符串,表示密码。

第二行一个正整数\(n\;(1\leqslant n\leqslant100)\),表示Kashtanka会说的单词数量。

接下来\(n\)行,每行一个两个字符长的字符串,表示Kashtanka会的单词。

输出:

YES或NO表示是否能做到。

题解:

  1. #include<cstdio>
  2. #include<set>
  3. #include<algorithm>
  4. #include<queue>
  5. #include<map>
  6. #define F(i,n) for(int i=1;i<=n;++i)
  7. #define R(i,a,b) for(int i=a;i<=b;++i)
  8. #define dF(i,n) for(int i=n;i>=1;--i)
  9. #define IINF 999999999
  10. using namespace std;
  11. int n,Ans=;
  12. char a[];
  13. char st[][];
  14. int h[],l[];
  15. int main(){
  16. scanf("%s",a);
  17. scanf("%d",&n);
  18. F(i,n){
  19. scanf("%s",st[i]);
  20. if(st[i][]==a[]&&st[i][]==a[]) Ans=;
  21. h[st[i][]]=;
  22. l[st[i][]]=;
  23. }
  24. if(h[a[]]&&l[a[]]) Ans=;
  25. if(Ans==) puts("YES");
  26. else puts("NO");
  27. return ;
  28. }

【B】和时间赛跑

题意:

你曾经有这样的经历吗?要出一套题,离比赛开始只有8小时了,可是你却一道题都没出。

Mr.江有过。但是他真的有一个很不可拒绝的借口:他面对着一个时空悖论,时间和空间互换了位置!

整个宇宙变成了一个巨大的钟表。时针、分针和秒针静静地躺在钟面上。时间静止了,钟表显示的时间是\(h\)时\(m\)分\(s\)秒。

Mr.江上次和教练谈话是\(t_{1}\)时,而比赛在\(t_{2}\)时开始。这意味着Mr.江需要从\(t_{1}\)指针移动到\(\t_{2}\)指针。

但Mr.江在空间上的移动,就意味着Mr.江在现实中的时间上的衰老。但是众所周知,Mr.江有无限的时间支配,所以我们不需要担心这个。

如果Mr.江的道路上有指针挡着,他就不能通过。当然,Mr.江可以顺时针或逆时针行走。

保证任意一个指针不在整时刻度上。

判断Mr.江能否成功准时举办比赛?(或者我们应该说“准空”?)

输入:

五个数\(h,m,s,t_{1},t_{2}\;(1\leqslant h\leqslant12,0\leqslant m,s\leqslant59,1\leqslant t_{1},t_{2}\leqslant12,t_{1}\neq t_{2})\)。

输出:

YES或NO表示能否从\(t_{1}\)到达\(t_{2}\)。

题解:

判断三个指针在不在\(t_{1},t_{2}\)的同一侧。

  1. #include<cstdio>
  2. #include<set>
  3. #include<algorithm>
  4. #include<queue>
  5. #include<map>
  6. #define F(i,n) for(int i=1;i<=n;++i)
  7. #define R(i,a,b) for(int i=a;i<=b;++i)
  8. #define dF(i,n) for(int i=n;i>=1;--i)
  9. #define IINF 999999999
  10. using namespace std;
  11. int h,m,s,t1,t2;
  12. int h1,h2,h3;
  13. int w1,w2,w3;
  14. int main(){
  15. scanf("%d%d%d%d%d",&h,&m,&s,&t1,&t2);
  16. if(h==) h=;
  17. if(t1==) t1=;
  18. if(t2==) t2=;
  19. h1=h*+m*+s;
  20. h2=m*+s*;
  21. h3=s*;
  22. t1*=, t2*=;
  23. // printf("%d %d %d %d %d\n",h1,h2,h3,t1,t2);
  24. if(t1>t2) swap(t1,t2);
  25. if(t1<=h1&&h1<=t2) w1=;
  26. if(t1<=h2&&h2<=t2) w2=;
  27. if(t1<=h3&&h3<=t2) w3=;
  28. if(w1==w2&&w2==w3) puts("YES");
  29. else puts("NO");
  30. return ;
  31. }

【C】资格预审赛

题意:

Snark和Phillip在为了将来的八强赛的资格预审赛做准备,他们的题库中有\(n\)道题,他们想从中选出一个非空子集,作为题目。

有\(k\)个队伍会参加比赛。有一些队伍已经知道了题库中的某些题。

为了让比赛对他们来说更有趣,每个队伍知道的题目最多占总题目中的一半。

判断Snark和Phillip能否出一套有趣的比赛。

输入:

第一行两个正整数\(n,k\;(1\leqslant n\leqslant10^{5},1\leqslant k\leqslant4)\),题库中题目总数和参加比赛的队伍数量。

接下来\(n\)行,每行\(k\)个整数,等于0或1。第\(i\)行的第\(j\)个数是1就表示第\(j\)队知道第\(i\)题,是0反之。

输出:

YES或NO表示能否出一套有趣的比赛。

题解:

可以证明,在队伍数量最多为4的情况下,最多选2道题就可以了。

举个例子,当选出4题时,可以成为有趣的比赛,那么选出其中两题,必定也可以成为有趣的比赛。

根据定义,最终题目所组成的矩阵每列最多只有两个1,而某列有两个1在某两题的位置上,就意味着这两题不能同时选出。

而只有4列,最多只有4对题不能同时选出,但是题目的组合有6对,所以至少能选出两种不同的题目组合满足要求。

当题目数量大于4或者等于3时,也是类似证法。

而选两题的时间是\(O(n^{2})\)的,不是很优秀,但是注意到,只有2^4=16种不同的题目,所以复杂度应该是16^2=256的。

  1. #include<cstdio>
  2. #include<set>
  3. #include<algorithm>
  4. #include<queue>
  5. #include<map>
  6. #define F(i,n) for(int i=1;i<=n;++i)5
  7. #define R(i,a,b) for(int i=a;i<=b;++i)
  8. #define dF(i,n) for(int i=n;i>=1;--i)
  9. #define IINF 999999999
  10. using namespace std;
  11. int n,m;
  12. int x[];
  13. int a[];
  14. int main(){
  15. scanf("%d%d",&n,&m);
  16. for(int i=;i<=n;++i){
  17. for(int j=;j<=m;++j) scanf("%d",&x[j]);
  18. a[x[]+x[]*+x[]*+x[]*]=;
  19. }
  20. if(a[]) {puts("YES"); return ;}
  21. else{
  22. for(int i=;i<;++i)
  23. for(int j=;j<;++j){
  24. if((i&j)==&&a[i]&&a[j]){
  25. puts("YES");
  26. return ;
  27. }
  28. }
  29. }
  30. puts("NO");
  31. return ;
  32. }

【D】巨大的字符串

题意:

有n(1<=n<=100)个01字符串,每个长度小于等于100。

共有m(1<=m<=100)个操作,操作为"x y",表示把第y个字符串接在第x个字符串后面,得到编号为总编号+1的新字符串,并询问这个字符串中最大的满足条件的k,使得所有k位的01字符串(共有2^k个)都是这个字符串的子串。

输入:

第一行,n。

接下来n行,每行一个01字符串,表示第i个字符串。

接下来一行,m。

接下来m行,每行2个正整数,xi和yi,表示第i个操作。

输出:

对于每个询问,输出对应的k。

题解:

可以证明,k大约是<=17的。

【codeforces】【比赛题解】#868 CF Round #438 (Div.1+Div.2)的更多相关文章

  1. 竞赛题解 - CF Round #524 Div.2

    CF Round #524 Div.2 - 竞赛题解 不容易CF有一场下午的比赛,开心的和一个神犇一起报了名 被虐爆--前两题水过去,第三题卡了好久,第四题毫无头绪QwQ Codeforces 传送门 ...

  2. Codeforces Round #438 (Div.1+Div.2) 总结

    本来兴致勃勃的想乘着这一次上紫,于是很早很早的到了机房 但是好像并没有什么用,反而rating-=47 Codeforces Round #438(Div.1+Div.2) 今天就这样匆匆的总结一下, ...

  3. Educational Codeforces Round 65 (Rated for Div. 2)题解

    Educational Codeforces Round 65 (Rated for Div. 2)题解 题目链接 A. Telephone Number 水题,代码如下: Code #include ...

  4. Educational Codeforces Round 53 (Rated for Div. 2) (前五题题解)

    这场比赛没有打,后来补了一下,第五题数位dp好不容易才搞出来(我太菜啊). 比赛传送门:http://codeforces.com/contest/1073 A. Diverse Substring ...

  5. Educational Codeforces Round 63 (Rated for Div. 2) 题解

    Educational Codeforces Round 63 (Rated for Div. 2)题解 题目链接 A. Reverse a Substring 给出一个字符串,现在可以对这个字符串进 ...

  6. Educational Codeforces Round 48 (Rated for Div. 2) CD题解

    Educational Codeforces Round 48 (Rated for Div. 2) C. Vasya And The Mushrooms 题目链接:https://codeforce ...

  7. Educational Codeforces Round 60 (Rated for Div. 2) 题解

    Educational Codeforces Round 60 (Rated for Div. 2) 题目链接:https://codeforces.com/contest/1117 A. Best ...

  8. Educational Codeforces Round 59 (Rated for Div. 2) DE题解

    Educational Codeforces Round 59 (Rated for Div. 2) D. Compression 题目链接:https://codeforces.com/contes ...

  9. Educational Codeforces Round 58 (Rated for Div. 2) 题解

    Educational Codeforces Round 58 (Rated for Div. 2)  题目总链接:https://codeforces.com/contest/1101 A. Min ...

随机推荐

  1. Educational Codeforces Round 56 Div. 2 翻车记

    A:签到. B:仅当只有一种字符时无法构成非回文串. #include<iostream> #include<cstdio> #include<cmath> #in ...

  2. BZOJ5105 CodePlus2017晨跑

    这个题???我WA了两发??? #include<iostream> #include<cstdio> #include<cmath> #include<cs ...

  3. bzoj4385 & POJ2015 Wilcze doły

    Description 给定一个长度为n的序列,你有一次机会选中一段连续的长度不超过d的区间,将里面所有数字全部修改为0.请找到最长的一段连续区间,使得该区间内所有数字之和不超过p. Input 第一 ...

  4. BZOJ2007 [Noi2010]海拔 【平面图最小割转对偶图最短路】

    题目链接 BZOJ2007 题解 这是裸题啊,,要是考试真的遇到就好了 明显是最小割,而且是有来回两个方向 那么原图所有向右的边转为对偶图向下的边 向左的边转为向上 向下转为向左 向上转为向右 然后跑 ...

  5. 【题解】打地鼠 SDOI2011 模拟 行列无关

    Prelude 为什么洛谷上的题解都是剪枝做的啊!就没有人写复杂度靠谱的算法吗! 传送到洛谷:( ̄. ̄) 传送到BZOJ:( ´・・)ノ(._.`) 本篇博客地址:o(><:)oo Sol ...

  6. python中的文件操作(2)

    a+,w+,r+的特点: r+:r+模式允许读和写,当对文件句柄只进行写操作时,tell(),seek()为写操作的‘指针’(也就是写到seek()处). 当只进行读操作时,tell(),seek() ...

  7. 《剑指offer》面试题28:字符串的排列(牛客网版本) java

    题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入描述: 输 ...

  8. oracle改进之将阿拉伯数字转换成中文数字

    本博客是自己在学习和工作途中的积累与总结,仅供自己参考,也欢迎大家转载,转载时请注明出处   http://www.cnblogs.com/king-xg/p/6839738.html 将阿拉伯数字转 ...

  9. Linux下U盘、SD卡挂载与卸载

    1.手动挂载/卸载U盘.SD卡 对于ARM Linux来说,第一次使用U盘或SD时,U盘这个文件目录是不能直接进入的,我们需要对其进行挂载,然后再接下来的使用中就可以直接进行使用了.通过再网上查资料, ...

  10. Shell记录-Shell脚本基础(三)

    if...fi 语句的基本控制语句,它允许Shell有条件作出决定并执行语句. 语法 if [ expression ] then Statement(s) to be executed if exp ...