[contest 781] 9.6

时间:2022-09-06 11:49:06

[contest 781] 9.6 - XJOI

czx的温暖题。。。

T1 军训

[contest 781] 9.6

[contest 781] 9.6

那这非常水呀。。。

就是求一下(n^2-m)/n^2。

先把n,m读进来模一下然后逆元一下就好了。

code:

 #include<cstdio>
 #include<cstring>
 #include<algorithm>
 #include<iostream>
 #define LL long long
 using namespace std;
 ;
 LL n,m,ans;
 char ch;
 bool fl;
 inline LL Q_pow(LL b,LL p){
     ;
     ) return b%TT;
     LL t=Q_pow(b,p>>); t=(t*t)%TT;
     >) return (t*b)%TT;
     else return t;
 }
 int main(){
     n=m=fl=;
     while (scanf("%c",&ch)!=EOF){
         ; continue;}
         ') break;
         ) n=(n*+ch-')%TT;
         +ch-')%TT;
     }
     ans=(((n*n-m)%TT)*Q_pow((n*n)%TT,TT-))%TT;
     printf("%lld",ans%TT);
     ;
 }

T2 萌萌哒的小XC

[contest 781] 9.6

[contest 781] 9.6

主要要想到把原图中联通的且同色的构成一个联通块,然后随便抓一个节点,必定是隔一层节点换一种颜色。

事实上,我们只需要找出新图当中的(最长链的长度+1)/2就好了。

因为在一条颜色相间的链上面,需要(长度+1)/2次操作使其变成同色。

而我们知道,如果我们把原树看成无根树,最长链旁延伸出很多子树,但是由于最长链不通过这颗子树,所以这颗子树的操作次数一定小于在最长链上的操作次数。

code:

 #include<cstdio>
 #include<cstring>
 #include<algorithm>
 using namespace std;
 ;
 char cha;
 int n,a[N],fa[N],ret,ans,Mx,Mxi,sta;
 ],son[N*],lnk[N];
 ],sonn[N*],lnkn[N];
 bool vis[N];
 inline int read(){
     ; char ch=getchar();
     ') ch=getchar();
     +ch-',ch=getchar();
     return x;
 }
 void add(int x,int y){nxt[++tot]=lnk[x],son[tot]=y,lnk[x]=tot;}
 void addn(int x,int y){nxtn[++totn]=lnkn[x],sonn[totn]=y,lnkn[x]=totn;}
 int get(int x){return fa[x]==x?x:fa[x]=get(fa[x]);}
 void DFS(int x,int y,int d){
     if (Mx<d) Mx=d,Mxi=x;
     for (int j=lnkn[x]; j; j=nxtn[j])
         );
 }
 int main(){
     n=read(),tot=,ans=0x3f3f3f3f;
     ; i<=n; i++){
         while (scanf("%c",&cha))
             if (cha=='B'||cha=='R') break;
         a[i]=(cha=='R');
     }
     ; i<=n; i++) fa[i]=i;
     ; i<n; i++){
         int x=read(),y=read(),fx=get(x),fy=get(y);
         add(x,y),add(y,x);
         if (a[x]==a[y]) fa[fx]=fy;
     }
     ; i<=n; i++)
         for (int j=lnk[i]; j; j=nxt[j]){
             int x=get(i),y=get(son[j]);
             if (x!=y) addn(x,y);
         }
     ; i<=n; i++) get(i);
     memset(vis,,sizeof vis);
     ; i<=n; i++) vis[;
     sta=),Mx=;
     DFS(sta,,);
     DFS(Mxi,,);
     printf()>>);
     ;
 }

T3 真假雪菜

[contest 781] 9.6

[contest 781] 9.6

[contest 781] 9.6

主思想当然是贪心,主要还是围绕着操作顺序一定是1,2,3。然后有些细节还不会证明。所以暂时先搁着。

难度不高,还是挺接近NOIP难度的。

[contest 781] 9.6的更多相关文章

  1. Codeforces 781D Axel and Marston in Bitland

    题目链接:http://codeforces.com/contest/781/problem/D ${F[i][j][k][0,1]}$表示是否存在从${i-->j}$的路径走了${2^{k}} ...

  2. Codeforces 781B&period; Innokenty and a Football League

    题目链接:http://codeforces.com/contest/781/problem/B 去tmd 2-SAT 直接贪心就可以过去了,优先选择第二种情况. 然而....可以被叉掉(数据水了) ...

  3. bitset在acm中的应用

    ps:最近碰到一些用bitset优化常数的题目,以前也有接触但是都没有记下来,所以来写一篇博文 记录以后碰到的类似的题目. 应用一: 优化boolean multiplication 在做dp的时候, ...

  4. bitset 位运算

    1. 判断一个数是否是2的方幂n > 0 && ((n & (n - 1)) == 0 ) 解释((n & (n-1)) == 0): 如果A&B==0, ...

  5. 2016 Multi-University Training Contest 6

    5/12 2016 Multi-University Training Contest 6 官方题解 打表找规律/推公式 A A Boring Question(BH) 题意: ,意思就是在[0,n] ...

  6. Programming Contest Problem Types

        Programming Contest Problem Types Hal Burch conducted an analysis over spring break of 1999 and ...

  7. hdu 4946 2014 Multi-University Training Contest 8

    Area of Mushroom Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  8. 2016 Multi-University Training Contest 2 D&period; Differencia

    Differencia Time Limit: 10000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Tot ...

  9. 2016 Multi-University Training Contest 1 G&period; Rigid Frameworks

    Rigid Frameworks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

随机推荐

  1. 深入理解MySQL开发性能优化&period;pptx

    深入理解MySQL开发性能优化.pptx,依旧上传baidu pan http://pan.baidu.com/s/1jIwGslS,视频暂未出,培训完成后会更新.

  2. 玩耍Hibernate系列&lpar;一&rpar;--基础知识

    Hibernate框架介绍: Hibernate  ORM  主要用于持久化对象(最常用的框架) Hibernate  Search 用于对对象进行搜索,底层基于Apache Lucene做的 Hib ...

  3. BZOJ 1044

    1044: [HAOI2008]木棍分割 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1393  Solved: 497[Submit][Statu ...

  4. Android -------- 用XmlPullParser解析器解析XML文件

  5. greenDAO简介

    了解android开发的人应该都会知道,android的数据库开发主要用到sqlite.greenDAO应该算是当前最火的数据库开源框架了吧,它是一个移动开发的ORM(object / relatio ...

  6. IOS 触摸事件分发机制详解

    欢迎大家前往云+社区,获取更多腾讯海量技术实践干货哦~ 作者:MelonTeam 前言 很多时候大家都不关心IOS触摸事件的分发机制的实现原理,当遇到以下几种情形的时候你很可能抓破头皮都找不到解决方案 ...

  7. awk 详解&plus;实例

    1. awk简介 awk是一种编程语言,用于在linux/unix下对文本和数据进行处理.数据可以来自标准输入.一个或多个文件,或其它命令的输出.它支持用户自定义函数和动态正则表达式等先进功能,是li ...

  8. MySQL笔记&lpar;7&rpar;---事务

    1.前言 前面具体讲了MySQL中的锁实现的方式,解释了是如何保证数据在并发情况下的可靠性,并提到了事务REPETABLE READ和READ COMMITTED,解释了一下这两种事务的不同.本章讲具 ...

  9. 机器学习: 共轭梯度算法(PCG)

    今天介绍数值计算和优化方法中非常有效的一种数值解法,共轭梯度法.我们知道,在解大型线性方程组的时候,很少会有一步到位的精确解析解,一般都需要通过迭代来进行逼近,而 PCG 就是这样一种迭代逼近算法. ...

  10. Debug 路漫漫-06

    FSBPR 迭代一轮就停止???…… 循环条件没有问题.. 达到收敛条件了?——参数变化小于1e-4…? deltaU =0 —— U没有更新?——incU < 0 —— 取消动量(前半部分即可 ...