BZOJ2152: 聪聪可可(点分治)

Time Limit: 3 Sec  Memory Limit: 259 MB

Submit: 4902  Solved: 2572

[Submit][Status][Discuss]

Description

聪聪和可可是兄弟俩,他们俩经常为了一些琐事打起来,例如家中只剩下最后一根冰棍而两人都想吃、两个人都想玩儿电脑(可是他们家只有一台电脑)……遇到这种问题,一般情况下石头剪刀布就好了,可是他们已经玩儿腻了这种低智商的游戏。他们的爸爸快被他们的争吵烦死了,所以他发明了一个新游戏:由爸爸在纸上画n个“点”,并用n-1条“边”把这n个“点”恰好连通(其实这就是一棵树)。并且每条“边”上都有一个数。接下来由聪聪和可可分别随即选一个点(当然他们选点时是看不到这棵树的),如果两个点之间所有边上数的和加起来恰好是3的倍数,则判聪聪赢,否则可可赢。聪聪非常爱思考问题,在每次游戏后都会仔细研究这棵树,希望知道对于这张图自己的获胜概率是多少。现请你帮忙求出这个值以验证聪聪的答案是否正确。

Input

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

Output

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

Sample Input

5 1 2 1 1 3 2 1 4 1 2 5 3

Sample Output

13/25 【样例说明】 13组点对分别是(1,1) (2,2) (2,3) (2,5) (3,2) (3,3) (3,4) (3,5) (4,3) (4,4) (5,2) (5,3) (5,5)。 【数据规模】 对于100%的数据,n<=20000。

HINT

Source

点分治的模板题

我们只需要统计出每个点在$\pmod 3$意义下的距离即可

每个点的答案为$sum[1] * sum[2] * 2 + sum[0] * sum[3]$

最后总的答案和$n^2$取个gcd就行

#include<cstdio>
#include<vector>
#include<algorithm>
#define Pair pair<int, int> 
#define MP(x, y) make_pair(x, y)
using namespace std;
const int MAXN = 20001, INF = 1e9 + 10;
inline int read() {
    char c = getchar(); int x = 0, f = 1;
    while(c < '0' || c > '9'){if(c == '-')f = -1; c = getchar();}
    while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
    return x * f;
}
vector<Pair> v[MAXN];
int N;
int siz[MAXN], maxsiz[MAXN], vis[MAXN], root, Sum, Mx, ans, dis[MAXN];
void FindRoot(int x, int fa) {
    siz[x] = 1; maxsiz[x] = 0;
    for(int i = 0; i < v[x].size(); i++) {
        int to = v[x][i].first, w = v[x][i].second;
        if(to == fa || vis[to]) continue;
        FindRoot(to, x);
        siz[x] += siz[to];
        if(siz[to] > maxsiz[x]) maxsiz[x] = siz[to];
    }
    maxsiz[x] = max(maxsiz[x], Sum - siz[x]);
    if(maxsiz[x] < Mx) Mx = maxsiz[x], root = x;
}
void GetRoot(int num, int x) {
    Sum = num; Mx = INF; root = 0; FindRoot(x, 0);    
}
int num = 0;
void GetDis(int x, int fa, int cur) {
    dis[++num] = cur % 3;
    for(int i = 0; i < v[x].size(); i++) {
        int to = v[x][i].first, w = v[x][i].second;
        if(to == fa || vis[to]) continue;
        GetDis(to, x, (cur + w) % 3); 
    }
}
int calc(int x, int len) {
    num = 0;
    GetDis(x, 0, len);
    int sum[3] = {};
    for(int i = 1; i <= num; i++) sum[dis[i] % 3]++;
    return sum[1] * sum[2] * 2 + sum[0] * sum[0];
}
void Solve(int x) {
    vis[x] = 1;
    ans += calc(x, 0);
    for(int i = 0; i < v[x].size(); i++) {
        int to = v[x][i].first, w = v[x][i].second;
        if(vis[to]) continue;
        ans -= calc(to, w);
        GetRoot(siz[to], to);
        Solve(root);
    }
}
int main() {
#ifdef WIN32
    freopen("a.in", "r", stdin);
#endif
    N = read();
    for(int i = 1; i <= N - 1; i++) {
        int x = read(), y = read(), z = read();
        v[x].push_back(MP(y, z));
        v[y].push_back(MP(x, z));
    }
    GetRoot(N, 1);
    Solve(root);
    int gcd = __gcd(ans, N * N);
    printf("%d/%d", ans / gcd, N * N / gcd);
    return 0;
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏HansBug's Lab

1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路

1624: [Usaco2008 Open] Clear And Present Danger 寻宝之路 Time Limit: 5 Sec  Memory L...

3296
来自专栏架构说

110. 平衡二叉树

世界分为三条线,两实一虚: 1. 当前时间线: 黑帽威廉时间线,凡是有黑帽威廉的都在当前时间 2. 历史时间线:白帽威廉时间线 (35年前),凡是有白帽威廉的都...

962
来自专栏我和未来有约会

[Silverlight动画]转向行为 - 对象回避

对象回避主题的完整意义是指,在机车行走的路线中存在一些障碍物,机车必须绕开、防止触碰到它们。听上去和碰撞检测有关,然而这仅仅是发生在预测阶段,也就是:“以我当前...

2055
来自专栏C语言及其他语言

【每日一题】问题 1146: 舍罕王的失算

关注我们 题目描述 相传国际象棋是古印度舍罕王的宰相达依尔发明的.舍罕王十分喜爱象棋,决定让宰相自己选择何种赏赐.这位聪明的宰相指着8*8共64格的象棋说:陛...

32911
来自专栏算法修养

HDU 1243 反恐训练营(最长公共序列)

反恐训练营 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav...

2757
来自专栏ml

hdu----(1849)Rabbit and Grass(简单的尼姆博弈)

Rabbit and Grass Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/3...

3557
来自专栏HansBug's Lab

3400: [Usaco2009 Mar]Cow Frisbee Team 奶牛沙盘队

3400: [Usaco2009 Mar]Cow Frisbee Team 奶牛沙盘队 Time Limit: 3 Sec  Memory Limit: 12...

2145
来自专栏程序员互动联盟

【基础编程】侃侃数据结构与算法-扯扯概念

? 为啥扯淡,因为我们开发人员很少用到它,目前流行的android开发有数据结构么?没有,至少你在用api的时候基本上是看不见的。c++有在STL基本容器中s...

38813
来自专栏章鱼的慢慢技术路

牛客网2018年全国多校算法寒假训练营练习比赛(第二场)

3344
来自专栏ml

hdu-----(4514)湫湫系列故事——设计风景线(树形DP+并查集)

湫湫系列故事——设计风景线 Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65535/3276...

3828

扫码关注云+社区