BZOJ2152: 聰聰可可(點分治)

来源:https://www.cnblogs.com/zwfymqz/archive/2018/07/12/9297748.html
-Advertisement-
Play Games

Description 聰聰和可可是兄弟倆,他們倆經常為了一些瑣事打起來,例如家中只剩下最後一根冰棍而兩人都想吃、兩個人都想玩兒電腦(可是他們家只有一臺電腦)……遇到這種問題,一般情況下石頭剪刀布就好了,可是他們已經玩兒膩了這種低智商的游戲。他們的爸爸快被他們的爭吵煩死了,所以他發明瞭一個新游戲:由 ...


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;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用閉包的方式實現一個累加函數 addNum,參數為 number 類型,每次返回的結果 = 上一次計算的值 + 傳入的值,如: addNum(10); //10 addNum(12); //22 addNum(30); //52 寫法一 寫法二 寫法三 ...
  • 一、變數、數據類型與運算符 1.變數 聲明變數: 2.數據類型 隱式轉換 強制轉換 3.運算符 1.算術運算符 2.賦值運算符和比較運算符 3.邏輯運算符 4.三元運算符 5.運算符優先順序 二、流程式控制制 1.條件語句 var readline = require("readline"); var r ...
  • 前言 在React項目的開發中經常會遇到這樣一個場景:嵌套組件與被嵌套組件的通信。 比如Tab組件啊,或者下拉框組件。 場景 這裡應用一個最簡單的Tab組件來呈現這個場景。 import React, { Component, PropTypes } from 'react' class Tab e ...
  • 組件有個屬性:hidden='' ,值為true/false ,當false的時候說明不隱藏,當true的時候說明隱藏,註意該隱藏是不保留組件位置的。 實現即 .js 配合.wxml 文件 一、在.js 文件下的 Page({}) 裡面 的data:{} 裡面 創建一個布爾類型的屬性 二、在.wxm ...
  • 1. 請求長度的限制 在HTTP協議中,從未規定GET/POST的請求長度限制,對於GET,對url的限制來源於瀏覽器或web伺服器,瀏覽器和伺服器限制了url的長度。因此,在使用GET請求時,傳輸數據會受到URL長度的限制。對於POST,由於沒有url傳值,理論上是不會受到限制的,但是實際上各個服 ...
  • 在我們的項目經常需要監聽一些鍵盤事件來觸發程式的執行,而Vue中允許在監聽的時候添加關鍵修飾符: 對於一些常用鍵,還提供了按鍵別名: 全部的按鍵別名: .enter .tab .delete (捕獲“刪除”和“退格”鍵) .esc .space .up .down .left .right 修飾鍵: ...
  • 問題:有兩個元素: A, B。兩則是嵌套關係,A是B的父節點。A和B都是塊元素。當在A上設置:margin: 0 auto的時候,B並沒有在頁面中居中。 margin: 0 auto 為什麼沒有生效? 解決:margin:0 auto;生效,需要一定的前提條件。 1 兩者是塊元素,即 display ...
  • 下麵是在變數開始的時候定義初始值 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...