闲来无事,打场CF,本人蒟蒻,考场A了前三道,第四有解答

正文

T1 Non-zero

是道水题。。。。

给你一个序列a。要求你输出最少的操作次数使这个序列的累和与累乘都不为0;

一次操作指给\(a_i\)+1.

我们的想法是先给每个零的+1,检查此时和是否为0,若为0,+1,否则直接输出答案

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. using namespace std;
  5. const int Maxn=101;
  6. int t,n,s,a[Maxn],sum;
  7. int main() {
  8. // freopen("a.in","r",stdin);
  9. t=read();
  10. while(t--){
  11. n=read();s=0;sum=0;
  12. for(int i=1;i<=n;i++){
  13. a[i]=read();
  14. sum+=a[i];
  15. }
  16. for(int i=1;i<=n;i++) if(a[i]==0) s++,sum++,a[i]++;//��֤ a[i]��Ϊ0
  17. if(sum!=0) printf("%d\n",s);
  18. else printf("%d\n",s+1);
  19. }
  20. return 0;
  21. }

我把快读删了。。。有-的

T2 Assigning to Classes

我们注意到,差值事实上是两个数之差,而这两个数都为子数组中的中位数,所以这两个数\(a\),\(b\),不妨设\(a>b\) ,从而,\(a \ge p_{k+1}\),而\(b \le p_{k}\), 这是显然的。

从而,最小值之差即为\(p_{k+1}-p_{k}\),这是可以取到的

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. #include <algorithm>
  5. using namespace std;
  6. const int Maxn=2*1e5+111;
  7. int t,a[Maxn],n;
  8. int main() {
  9. // freopen("a.in","r",stdin);
  10. t=read();
  11. while(t--){
  12. n=read();
  13. for(int i=1;i<=2*n;i++) a[i]=read();
  14. sort(a+1,a+1+2*n);
  15. printf("%d\n",a[n+1]-a[n]);
  16. }
  17. return 0;
  18. }

T3 Anu Has a Function

我们注意到 ,事实上对于\(f(i,j)<i\),从而进一步的讨论,把每一个数分解为二进制,如果这些数而二进制的某位上1的个数超过1,则这一位的答案一定为0,所以我们只需要从最高位开始扫,扫到某一位只有一个一即可

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. #include <algorithm>
  5. using namespace std;
  6. const int Maxn=1e5+111;
  7. int r[50],a[Maxn],n;
  8. bool s[Maxn][50];
  9. int main() {
  10. // freopen("a.in","r",stdin);
  11. n=read();
  12. for(int i=1;i<=n;i++) {
  13. a[i]=read();
  14. int k=a[i];
  15. for(int j=0;k>0;j++){
  16. if(k&1) s[i][j]=1,r[j]++;
  17. k>>=1;
  18. }
  19. }
  20. int u=0;bool flag=1;
  21. for(int j=50;j>=0&&flag;j--)
  22. if(r[j]==1)
  23. for(int i=1;i<=n;i++)
  24. if(s[i][j]){
  25. u=i;
  26. flag=0;
  27. break;
  28. }
  29. if(u!=0) printf("%d",a[u]);
  30. for(int i=1;i<=n;i++) if(i!=u) printf(" %d",a[i]);
  31. return 0;
  32. }

T4 Aerodynamic

我们可以推出再若在\(P(x_0,y_0)\)中有两点\((x_1,y_1)\),和\((0,0)\),则必有\(P(x_0-x_1,y_0-y_1)\) 包含两点\((0,0)\),\((-x_1,-y_)\),从而我们可以得到T一定是中心对称的,只要我们检查P是否具有中心对称性即可

  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. #include <algorithm>
  5. using namespace std;
  6. const int Maxn=1e5+111;
  7. double x[Maxn],y[Maxn];
  8. int n;
  9. int main() {
  10. // freopen("a.in","r",stdin);
  11. n=read();
  12. if(n&1){
  13. printf("No");
  14. return 0;
  15. }
  16. for(int i=1;i<=n;i++) scanf("%lf%lf",&x[i],&y[i]);
  17. x[n+1]=(x[1]+x[n/2+1])/2;y[n+1]=(y[1]+y[n/2+1])/2;n/=2;
  18. for(int i=2;i<=n;i++)
  19. if(x[2*n+1]!=((x[i]+x[i+n])/2)||y[2*n+1]!=((y[i]+y[i+n])/2)){
  20. printf("No");
  21. return 0;
  22. }
  23. printf("YES");
  24. return 0;
  25. }

蒟蒻终能变为神犇

CF #618 div.2的更多相关文章

  1. CF #376 (Div. 2) C. dfs

    1.CF #376 (Div. 2)    C. Socks       dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...

  2. CF #375 (Div. 2) D. bfs

    1.CF #375 (Div. 2)  D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...

  3. CF #374 (Div. 2) D. 贪心,优先队列或set

    1.CF #374 (Div. 2)   D. Maxim and Array 2.总结:按绝对值最小贪心下去即可 3.题意:对n个数进行+x或-x的k次操作,要使操作之后的n个数乘积最小. (1)优 ...

  4. CF #374 (Div. 2) C. Journey dp

    1.CF #374 (Div. 2)    C.  Journey 2.总结:好题,这一道题,WA,MLE,TLE,RE,各种姿势都来了一遍.. 3.题意:有向无环图,找出第1个点到第n个点的一条路径 ...

  5. CF #371 (Div. 2) C、map标记

    1.CF #371 (Div. 2)   C. Sonya and Queries  map应用,也可用trie 2.总结:一开始直接用数组遍历,果断T了一发 题意:t个数,奇变1,偶变0,然后与问的 ...

  6. CF #365 (Div. 2) D - Mishka and Interesting sum 离线树状数组

    题目链接:CF #365 (Div. 2) D - Mishka and Interesting sum 题意:给出n个数和m个询问,(1 ≤ n, m ≤ 1 000 000) ,问在每个区间里所有 ...

  7. CF #365 (Div. 2) D - Mishka and Interesting sum 离线树状数组(转)

    转载自:http://www.cnblogs.com/icode-girl/p/5744409.html 题目链接:CF #365 (Div. 2) D - Mishka and Interestin ...

  8. [CF百场计划]#2 Codeforces Round #618 (Div. 2)

    A. Non-zero Description: Guy-Manuel and Thomas have an array \(a\) of \(n\) integers [\(a_1, a_2, \d ...

  9. CF#138 div 1 A. Bracket Sequence

    [#138 div 1 A. Bracket Sequence] [原题] A. Bracket Sequence time limit per test 2 seconds memory limit ...

随机推荐

  1. 在Mysql中,事务是如何实现的呢?

    hello大家好,我是一个爱看底层的小码,对于每一个学习mysql数据库的同学来说,事务都是一个绕不开的话题,简单的说来事务是指访问并可能更新数据库中各项数据项的一个程序执行单元.事务的四个特征无非就 ...

  2. Python 中的三元运算(软件测试中运用)

    前言 在java中,有类似于 (condition) ? a :b 这样的语法,表示如果condition 为真,返回a,反之返回b.我们称之为三元运算. 那Python中,有没有这样的语法呢,非常遗 ...

  3. 如何为wordpress 添加favicon

    制做一张16px×16px(像素)大小的图片命名favicon并修改扩展名为.ico,即favicon.ico文件! 方法1:将favicon.ico图标上传到WordPress博客空间的根目录(方法 ...

  4. NetworkX包

    官方教程 NetworkX是一个创建,操作,研究复杂网络的结构,动态,功能的python包. #创建一个network import networkx as nx G = nx.Graph() #no ...

  5. HDU_4570_区间dp

    http://acm.hdu.edu.cn/showproblem.php?pid=4570 连题目都看不懂,直接找了题解,copy了过来= =. 一个长度为n的数列,将其分成若干段(每一段的长度要& ...

  6. 一口气说出 9种 分布式ID生成方式,面试官有点懵了

    整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 本文作者:程序员内点事 原文链接:https://mp.weix ...

  7. (原)NSQ源码阅读和分析(1)

    原文出处:https://www.cnblogs.com/lihaiping/p/12324371.html 本文记录自己在阅读和学习nsq源码的时候的一些学习笔记,主要目的是个人总结和方便后期查阅. ...

  8. My introduction

    Vistors 访客统计

  9. Burpsuite Pro 2020.1最新破解版

    简介 Burp Suite 是用于攻击web 应用程序的集成平台,包含了许多工具.Burp Suite为这些工具设计了许多接口,以加快攻击应用程序的过程.所有工具都共享一个请求,并能处理对应的HTTP ...

  10. Keepalived 工作原理和配置说明

    keepalived是什么: 简单来说 Keepalived 的功能功能1.使用VRRP协议 来控制一组高可用(HA) 主备系统,一台master工作,一台slave热备:master失效后slave ...