洛谷 P2634 [国家集训队]聪聪可可 解题报告

时间:2022-12-23 11:17:53

P2634 [国家集训队]聪聪可可

题目描述

聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃、两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好了,可是他们已经玩儿腻了这种低智商的游戏。

他们的爸爸快被他们的争吵烦死了,所以他发明了一个新游戏:由爸爸在纸上画\(n\)个“点”,并用\(n-1\)条“边”把这\(n\)个“点”恰好连通(其实这就是一棵树)。并且每条“边”上都有一个数。接下来由聪聪和可可分别随即选一个点(当然他们选点时是看不到这棵树的),如果两个点之间所有边上数的和加起来恰好是3的倍数,则判聪聪赢,否则可可赢。

聪聪非常爱思考问题,在每次游戏后都会仔细研究这棵树,希望知道对于这张图自己的获胜概率是多少。现请你帮忙求出这个值以验证聪聪的答案是否正确。

输入输出格式

输入格式:

输入的第\(1\)行包含\(1\)个正整数\(n\)。后面\(n-1\)行,每行3个整数\(x,y,w\),表示\(x\)号点和\(y\)号点之间有一条边,上面的数是\(w\)。

输出格式:

以即约分数形式输出这个概率(即“\(a/b\)”的形式,其中\(a\)和\(b\)必须互质。如果概率为\(1\),输出“\(1/1\)”)。

说明:

对于\(100\%\)的数据,\(n \le 20000\)。


淀粉质裸题

对按顺序统计每颗子树,拿桶装一装,随便统计一下

注意这样的复杂度是\(O(nlogn)\)


Code:

#include <cstdio>
#include <cstring>
const int N=2e4+10;
const int inf=0x3f3f3f3f;
int head[N],to[N<<1],Next[N<<1],edge[N<<1],cnt;
void add(int u,int v,int w)
{
to[++cnt]=v,Next[cnt]=head[u],edge[cnt]=w,head[u]=cnt;
}
int gcd(int x,int y){return y?gcd(y,x%y):x;}
int siz[N],buct[4],tmp[4],mi,id,del[N],ans,n;
void getroot(int now,int fa,int su)
{
siz[now]=1;int mx=0;
for(int i=head[now];i;i=Next[i])
{
int v=to[i];
if(!del[v]&&v!=fa)
{
getroot(v,now,su);
mx=mx>siz[v]?mx:siz[v];
siz[now]+=siz[v];
}
}
mx=mx>su-siz[now]?mx:su-siz[now];
if(mx<mi) mi=mx,id=now;
}
void dfs(int now,int fa,int dis)
{
++tmp[dis],siz[now]=1;
ans+=buct[3-dis];
if(!dis) ans+=buct[0];
for(int i=head[now];i;i=Next[i])
{
int v=to[i];
if(!del[v]&&v!=fa)
dfs(v,now,(dis+edge[i])%3),siz[now]+=siz[v];
}
}
void divide(int now,int su)
{
mi=inf;
getroot(now,0,su);
now=id,del[now]=1;
memset(buct,0,sizeof(buct));
for(int i=head[now];i;i=Next[i])
{
int v=to[i];
if(!del[v])
{
memset(tmp,0,sizeof(tmp));
dfs(v,now,edge[i]);
for(int j=0;j<=2;j++) buct[j]+=tmp[j];
}
}
ans+=buct[0];
for(int i=head[now];i;i=Next[i])
if(!del[to[i]])
divide(to[i],siz[to[i]]);
}
int main()
{
scanf("%d",&n);
for(int u,v,w,i=1;i<n;i++)
{
scanf("%d%d%d",&u,&v,&w);
w%=3;
add(u,v,w),add(v,u,w);
}
divide(1,n);
int a=(ans<<1)+n,b=n*n;
int GCD=gcd(a,b);
a/=GCD,b/=GCD;
printf("%d/%d",a,b);
return 0;
}

2018.9.15

洛谷 P2634 [国家集训队]聪聪可可 解题报告的更多相关文章

  1. 模板—点分治A(容斥)(洛谷P2634 &lbrack;国家集训队&rsqb;聪聪可可)

    洛谷P2634 [国家集训队]聪聪可可 静态点分治 一开始还以为要把分治树建出来……• 树的结构不发生改变,点权边权都不变,那么我们利用刚刚的思路,有两种具体的分治方法.• A:朴素做法,直接找重心, ...

  2. 洛谷 P2634 &lbrack;国家集训队&rsqb;聪聪可可-树分治&lpar;点分治,容斥版&rpar; &plus;读入挂&plus;手动O2优化吸点氧才过。。。-树上路径为3的倍数的路径数量

    P2634 [国家集训队]聪聪可可 题目描述 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一 ...

  3. 洛谷P2634 &lbrack;国家集训队&rsqb;聪聪可可 (点分治)

    题目描述 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好了,可是他们已 ...

  4. 洛谷-P2634 &lbrack;国家集训队&rsqb;聪聪可可 点分治

    Description 聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃.两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好 ...

  5. &lbrack;洛谷P2634&rsqb;&lbrack;国家集训队&rsqb;聪聪可可

    题目大意:给你一棵树,随机选两个点,求它们之间路径长度是$3$的倍数的概率 题解:点分治,求出当前状态的重心,然后求出经过重心的答案,接着分治每棵子树.注意考虑重复计算的情况 卡点:无 C++ Cod ...

  6. 洛谷 P2634 &lbrack;国家集训队&rsqb;聪聪可可

    点分板子2333 注释都是错过的地方 #include<cstdio> #include<algorithm> using namespace std; typedef lon ...

  7. 洛谷P2634 &lbrack;国家集训队&rsqb;聪聪可可&lpar;点分治&rpar;

    传送门 题意: 给出一颗树,每条边都有一定的边权. 先问点之间路径和为\(3\)的倍数的点对有多少. 思路: 点分治模板题. 可以将问题转化为经过一个点\(t\)的路径和不经过点\(t\)的路径两种情 ...

  8. 洛谷P2634 &lbrack;国家集训队&rsqb;聪聪可可 点分治模板

    题意 在一棵树上任意选两个点,求它们距离模3为0的概率. 分析 树分治模板 Code #include<bits/stdc++.h> #define fi first #define se ...

  9. &lbrack;洛谷P1527&rsqb; &lbrack;国家集训队&rsqb;矩阵乘法

    洛谷题目链接:[国家集训队]矩阵乘法 题目背景 原 <补丁VS错误>请前往P2761 题目描述 给你一个N*N的矩阵,不用算矩阵乘法,但是每次询问一个子矩形的第K小数. 输入输出格式 输入 ...

随机推荐

  1. 深入浅出 Java 8 Lambda 表达式

    摘要:此篇文章主要介绍 Java8 Lambda 表达式产生的背景和用法,以及 Lambda 表达式与匿名类的不同等.本文系 OneAPM 工程师编译整理. Java 是一流的面向对象语言,除了部分简 ...

  2. hdoj 1237 简单计算器

    简单计算器 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  3. PHP IP互换数字&lbrack;转&rsqb;

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. Android之旅十八 百度地图环境搭建

    在android中使用百度地图,我们能够先看看百度地图对应的SDK信息:http://developer.baidu.com/map/index.php? title=androidsdk,它里面基本 ...

  5. 深入 char &ast; &comma;char &ast;&ast; &comma;char a&lbrack; &rsqb; &comma;char &ast;a&lbrack;&rsqb; 内核

    本文来自CSDN博客:daiyutage的文章 来源网页地址:http://blog.csdn.net/daiyutage/article/details/8604720 本人觉得这是一编很有价值的文 ...

  6. Layui常见问题

    为什么表单不显示?当你使用表单时,Layui会对select.checkbox.radio等原始元素隐藏,从而进行美化修饰处理.但这需要依赖于form组件,所以你必须加载 form,并且执行一个实例. ...

  7. SharedPreference映射Java类

    package com.overlook.weagree.util; import android.app.Activity; import android.content.Context; impo ...

  8. python2的比较函数,cmp

    class Shu(object): def __init__(self,ss): self.ss = ss def __str__(self): return '(%s: %s)' % (self. ...

  9. tkinter绑定鼠标滚轮滚动事件 canvas&period;bind&lpar;&quot&semi;&lt&semi;MouseWheel&gt&semi;&quot&semi;&comma; processWheel&rpar; 失效

    其实,不同系统不一样,我的是Ubuntu 所以是<Button-4>   <Button-5> 见下: 来自:https://*.com/questio ...

  10. 扩展 StackExchange&period;Redis 支持实体

    一.StackExchange.Redis StackExchange.Redis是由Stack Overflow开发的C#语言Redis客户端,使用广泛,本文针对 StackExchange.Red ...