青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

算法學社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0

題目描述:

    給你一個N(N<10000)個點的有權樹,請問距離不超過K(K<1,000,000,000)的點對有多少個?

吐槽:

    1. 大家想不想看男人八題的總結? 有需求的話我就一天寫一篇~~~~ (之前切了3道...不過寫的很挫)
    2. 代碼寫的很挫,加上各種注釋/調試語句干了2.5k...
    3. 說好的今天學塊鏈呢...


算法分析:

    又是一道計數問題,總的想法是分治然后容斥...
    對于一個有根樹,計算路徑經過root的點對的個數。如果被計算出來了,再去計算它的子樹。
    問題是如何保證它的子樹分布的比較“均勻”呢?  有個定理:
        存在一個點使得分出的子樹的結點個數均不大于 N / 2 (證明略)
    我們的目的就是找到一個這樣的點,即樹的重心(可能有多個)。
    做法就是從任意一點開始做樹形DP,對于某個點u判斷每個子樹的sum值和SUM-sum[u]的值是否全部不大于n/2...
    
    分(divide)的問題解決了,那么如果治(conquer)呢?
    我們要求經過root且長度不超過K的所有路徑,也就是求所有(deep[u]+deep[v]<=K ----- 1) (u,v不在同一個root的兒子下面)的點對(deep[u]是值u到root的距離)
    直接求“u,v不屬于同一個root的兒子”的點對總數比較困難,我們可以容斥著做:
    ans = (所有滿足1式的點對) - (root的兒子 a(1...m)下面所有滿足1式的點對) (計算m次)
    計算一次所有滿足1式的點對的方法是
        1. 根據deep值從小到大排序
        2. 掃一遍,維護一個值left,使left是val[left] + val[i] <=K的最大值
    這樣分治的每一層時間復雜度是O(NlogN)
    一共分治logN層 總復雜度(N*(logN)^2)
  1 #include<iostream>
  2 #include<cstdio>
  3 #include<cassert>
  4 #include<algorithm>
  5 using namespace std;
  6 #define re(i,n) for(int i=0;i<n;i++)
  7 #define re3(i,n) for(int i=1;i<n;i++)
  8 int n,e,size,g,len,k,__ANS;
  9 const int V = 10005;
 10 const int E = V*2;
 11 int head[V] , nxt[E] , pnt[E], hash[E], cost[E], sum[V], tmp[V], dep[V];
 12 template <typename T> inline void chkmax(T &a, const T b) {if(a < b) a = b;}
 13 void dfs(int u,int f){
 14     sum[u] = 1;
 15     bool flag = 0;
 16     for(int i = head[u]; i != -1; i = nxt[i]){
 17         if(hash[i]) continue;
 18         int v = pnt[i];
 19         if(v == f) continue;
 20         dfs(v,u);
 21         if(sum[v] > size /2) flag = 1;
 22         sum[u] += sum[v];
 23 //        cout<<"u: "<<u<<" v: "<<v<<" "<<sum[v]<<endl;
 24     }
 25     if(!flag && sum[u] > size/2) g = u;
 26 //    cout<<"u: "<<u<<" "<<sum[u]<<endl;
 27 }
 28 void dfs1(int u,int f,int d){
 29     dep[u] = d;
 30     tmp[len++] = d;
 31     for(int i = head[u]; i!= -1;i=nxt[i]){
 32         if(hash[i]) continue;
 33         int v = pnt[i];
 34         if(v == f) continue;
 35         dfs1(v,u,d+ cost[i]);
 36     }
 37 }
 38 void dfs2(int u,int f){
 39     tmp[len++] = dep[u];
 40     for(int i = head[u]; i!=-1; i=nxt[i]){
 41         if(hash[i]) continue;
 42         int v = pnt[i];
 43         if(v!=f) dfs2(v,u);
 44     }
 45 }
 46 int cal_SUM(){
 47     int SUM = 0,l=0;
 48     sort(tmp,tmp+len);
 49 //    re(i,len) cout<<tmp[i]<<" "; cout<<endl;
 50     re3(i,len){
 51         while(tmp[l]+tmp[i]>k) l --;
 52         l ++;
 53         SUM += l;
 54     }
 55 //    cout<<"SUM: "<<SUM<<endl;
 56     return SUM;
 57 }
 58 int dfs3(int u,int f){
 59     sum[u] = 1;
 60     for(int i= head[u];i!=-1;i=nxt[i]){
 61         if(hash[i] || pnt[i]==f) continue;
 62         else sum[u] += dfs3(pnt[i],u);
 63     }
 64     return sum[u];
 65 }
 66 void cal(int x,int s){
 67     g = -1, size = s;
 68 //    cout<<x<<" "<<s<<endl;
 69     dfs(x,x);
 70     assert(g>=0);
 71 //    cout<<g<<endl;
 72     //// find zhongxin
 73     len = 0;
 74     dfs1(g,g,0);
 75     assert(len == size);
 76     int SUM = cal_SUM();
 77     for(int i = head[g]; i!=-1; i=nxt[i]){
 78         if(hash[i]) continue;
 79         int v= pnt[i];
 80         hash[i] = hash[i^1] = 1;
 81         len = 0;
 82         dfs2(v,v); SUM -= cal_SUM();
 83         hash[i] = hash[i^1] = 0;
 84     }
 85     __ANS += SUM;
 86 //    cout<<SUM<<endl;
 87     dfs3(g,g);
 88     ///// CAL SUM
 89     for(int i = head[g]; i!=-1;i=nxt[i]){
 90         if(hash[i]) continue;
 91         int v = pnt[i];
 92         hash[i] = hash[i^1] = 1;
 93         cal(v, sum[v]);
 94         hash[i] = hash[i^1] = 0;
 95     }
 96     // DIVIDE AND CONQURE
 97 }
 98 void add_edge(int u,int v,int c){
 99     nxt[e] = head[u];
100     head[u] = e;
101     pnt[e] = v;
102     cost[e++] = c;
103 }
104 int main(){
105     while(~scanf("%d%d",&n,&k) && !(!n&&!k)){
106         re(i,n) head[i] = -1;
107         int u,v,c;
108         e = 0;
109         re(i,n-1) {
110             scanf("%d%d%d",&u,&v,&c);
111             add_edge(u-1,v-1,c); add_edge(v-1,u-1,c);
112         }
113         __ANS = 0;
114         cal(0,n);
115         printf("%d\n",__ANS);
116     }
117     return 0;
118 }
119 
posted on 2012-05-02 16:58 西月弦 閱讀(481) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告經典題目
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久精品官网| 国产精品成人一区二区网站软件| 亚洲精品久久久久久久久| 久久爱www.| 亚洲一区二区三区影院| 亚洲一区免费看| 亚洲欧美自拍偷拍| 久久精品欧美日韩| 美女精品网站| 欧美三级网址| 国产婷婷色一区二区三区在线| 国产老肥熟一区二区三区| 亚洲国产电影| 亚洲精品久久久久久一区二区| 亚洲激情电影在线| 一本色道久久综合亚洲精品婷婷| 亚洲影院免费| 美女日韩欧美| 亚洲美女视频| 久久精品人人做人人爽电影蜜月| 欧美大片专区| 国产欧美一区二区三区在线老狼 | 国产精品久久久久久久久久久久久| 国产精品久久久久aaaa樱花| 国产综合久久久久影院| 99视频+国产日韩欧美| 欧美在线视频全部完| 欧美大片免费久久精品三p| 亚洲精品日韩激情在线电影 | 久久gogo国模裸体人体| 女仆av观看一区| 国产精品毛片高清在线完整版| 国内一区二区三区在线视频| 在线一区二区日韩| 欧美**字幕| 亚洲欧美日韩精品| 欧美另类videos死尸| 狠狠色狠色综合曰曰| 午夜精品网站| 99视频超级精品| 免费久久99精品国产自在现线| 国产精品视频yy9099| 99国产一区| 欧美成人精品在线播放| 午夜精品久久久久影视| 欧美色中文字幕| 亚洲精品一区二区在线观看| 久久久久在线观看| 香蕉成人啪国产精品视频综合网| 欧美日韩精选| 日韩午夜高潮| 亚洲电影免费在线| 久久综合中文| 影音先锋久久精品| 久久综合给合久久狠狠狠97色69| 亚洲欧美国产三级| 国产精品捆绑调教| 亚洲欧美国产日韩天堂区| 亚洲精品永久免费| 欧美精选午夜久久久乱码6080| 在线观看欧美一区| 男女av一区三区二区色多| 欧美综合77777色婷婷| 国产一区二区三区四区在线观看 | 国产在线日韩| 极品尤物av久久免费看| 欧美在线你懂的| 一区二区三区在线观看欧美 | 欧美日韩情趣电影| 老司机午夜精品视频在线观看| 欧美激情国产精品| 久久日韩精品| 国产裸体写真av一区二区| 亚洲三级电影全部在线观看高清| 国产在线国偷精品产拍免费yy| 亚洲精品一二三| 一区精品在线| 午夜免费电影一区在线观看| 亚洲在线第一页| 欧美日韩精品不卡| 亚洲人精品午夜| 亚洲国产天堂久久国产91| 久久国内精品自在自线400部| 午夜精品久久久久久久蜜桃app | 国产一区二区三区久久悠悠色av | 极品尤物av久久免费看| 午夜日韩视频| 午夜一区二区三视频在线观看| 欧美日韩国产在线播放| 亚洲高清免费视频| 91久久精品国产| 免费观看一级特黄欧美大片| 欧美多人爱爱视频网站| 亚洲国产成人av| 老司机精品导航| 欧美成人免费va影院高清| 亚洲国产91色在线| 欧美成人午夜| 亚洲精品日韩综合观看成人91| 日韩午夜精品视频| 欧美日韩在线看| 在线一区二区三区四区| 香蕉国产精品偷在线观看不卡 | 亚洲经典在线| 欧美成人亚洲成人日韩成人| 欧美国产精品一区| 日韩五码在线| 欧美色播在线播放| 亚洲视频免费| 西西人体一区二区| 国产一区二区三区四区老人| 久久久久成人精品免费播放动漫| 玖玖精品视频| 亚洲另类自拍| 亚洲小说区图片区| 久久久综合网站| 欧美激情精品久久久久久| 99国产精品视频免费观看| 欧美午夜久久久| 午夜视频一区二区| 毛片精品免费在线观看| 最新国产成人在线观看| 欧美日韩精品| 久久精品国产一区二区电影| 欧美成人四级电影| 亚洲视频播放| 国内精品视频在线播放| 欧美多人爱爱视频网站| 亚洲午夜久久久久久尤物| 久久免费视频在线观看| 日韩一本二本av| 国产日韩亚洲欧美综合| 你懂的视频一区二区| 亚洲天堂av在线免费| 欧美成人免费网站| 香蕉久久夜色精品国产| 亚洲全黄一级网站| 国产午夜精品全部视频播放| 男人插女人欧美| 午夜精品久久久久99热蜜桃导演| 欧美福利小视频| 欧美一区二区三区四区在线观看| 亚洲高清自拍| 国产视频在线观看一区二区三区| 欧美xx69| 久久成人人人人精品欧| 日韩一级视频免费观看在线| 美女脱光内衣内裤视频久久影院 | 欧美性猛交xxxx乱大交蜜桃| 久久久www| 亚洲一区二区三区在线看| 亚洲国产精品va在线看黑人动漫| 久久精品国产2020观看福利| 亚洲午夜视频在线观看| 亚洲七七久久综合桃花剧情介绍| 国产亚洲精品成人av久久ww| 欧美日韩一级视频| 欧美福利一区二区| 久久久久久噜噜噜久久久精品| 制服诱惑一区二区| 亚洲精选一区二区| 欧美激情在线播放| 免费不卡视频| 久久久美女艺术照精彩视频福利播放| 亚洲深夜激情| 一区二区三区视频在线观看| 亚洲国产精品小视频| 黄色一区二区在线观看| 国产又爽又黄的激情精品视频| 国产精品爽爽ⅴa在线观看| 欧美偷拍另类| 欧美午夜精品理论片a级大开眼界| 欧美激情综合五月色丁香| 免费毛片一区二区三区久久久| 久久久欧美精品| 欧美11—12娇小xxxx| 欧美成人精品在线观看| 欧美国产日韩在线| 欧美国产日韩视频| 欧美日韩高清区| 欧美日韩一区综合| 国产精品日日做人人爱| 国产欧美日韩一区二区三区在线 | 久久久精彩视频| 亚洲福利视频免费观看| 欧美日韩精品一本二本三本| 欧美精品一线| 欧美无乱码久久久免费午夜一区| 欧美午夜精品伦理| 国产欧美精品日韩精品| 国产亚洲欧美一区二区三区| 激情久久五月天| 91久久国产综合久久| 99国产精品久久久久久久成人热 | 久久夜色精品国产亚洲aⅴ| 久久亚洲不卡| 亚洲高清激情| 在线亚洲精品福利网址导航| 午夜国产精品影院在线观看 | 亚洲第一主播视频|