zoukankan      html  css  js  c++  java
  • 洛谷 P2634 [国家集训队]聪聪可可

    点分板子2333

    注释都是错过的地方

     1 #include<cstdio>
     2 #include<algorithm>
     3 using namespace std;
     4 typedef long long LL;
     5 struct E
     6 {
     7     LL to,nxt,d;
     8 }e[40100];
     9 LL f1[20010],ne,sz[20010];
    10 LL n,sum,root,dep[20010],ans,fx[20010];
    11 LL tmp[3];
    12 bool vis[20010];
    13 void getroot(LL u,LL fa)
    14 {
    15     sz[u]=1;fx[u]=0;
    16     for(LL k=f1[u];k;k=e[k].nxt)
    17         if(!vis[e[k].to]&&e[k].to!=fa)
    18         {
    19             getroot(e[k].to,u);
    20             sz[u]+=sz[e[k].to];
    21             fx[u]=max(fx[u],sz[e[k].to]);
    22         }
    23     fx[u]=max(fx[u],sum-sz[u]);
    24     if(fx[u]<fx[root])    root=u;
    25 }
    26 void getsz(LL u,LL fa)
    27 {
    28     sz[u]=1;
    29     for(LL k=f1[u];k;k=e[k].nxt)
    30         if(!vis[e[k].to]&&e[k].to!=fa)
    31         {
    32             getsz(e[k].to,u);
    33             sz[u]+=sz[e[k].to];
    34         }
    35 }
    36 void getdeep(LL u,LL fa)
    37 {
    38     tmp[dep[u]%3]++;
    39     for(LL k=f1[u];k;k=e[k].nxt)
    40         if(!vis[e[k].to]&&e[k].to!=fa)
    41         {
    42             dep[e[k].to]=dep[u]+e[k].d;
    43             getdeep(e[k].to,u);
    44         }
    45 }
    46 LL cal(LL u,LL cost)
    47 {
    48     tmp[0]=tmp[1]=tmp[2]=0;dep[u]=cost;
    49     getdeep(u,0);
    50     return tmp[0]*tmp[0]+2*tmp[1]*tmp[2];
    51 }
    52 void solve(LL u)
    53 {
    54     ans+=cal(u,0);
    55     vis[u]=1;//
    56     for(LL k=f1[u];k;k=e[k].nxt)
    57         if(!vis[e[k].to])
    58         {
    59             //vis[e[k].to]=1;
    60             getsz(e[k].to,0);
    61             sum=sz[e[k].to];//
    62             root=0;getroot(e[k].to,0);
    63             ans-=cal(e[k].to,e[k].d);//ans-=cal(e[k].to,u);
    64             solve(root);
    65         }
    66 }
    67 int main()
    68 {
    69     LL i,x,y,w;
    70     fx[0]=0x3f3f3f3f;
    71     scanf("%lld",&n);
    72     for(i=1;i<n;i++)
    73     {
    74         scanf("%lld%lld%lld",&x,&y,&w);
    75         e[++ne].to=y;e[ne].nxt=f1[x];e[ne].d=w;f1[x]=ne;
    76         e[++ne].to=x;e[ne].nxt=f1[y];e[ne].d=w;f1[y]=ne;
    77     }
    78     sum=n;getroot(1,0);
    79     solve(root);
    80     LL a1=ans,a2=n*n;LL g=__gcd(a1,a2);
    81     a1/=g;a2/=g;
    82     printf("%lld/%lld",a1,a2);
    83     return 0;
    84 }
  • 相关阅读:
    EVRYTHNG.H
    关于轮胎尺寸问题
    常见内核数据结构.doc
    i5处理器的台式机[百度知道]
    debug和release版区别
    booklist 转
    windows 系统编程 Chap7 线程和调度
    一个超级简单的dwr配置文件,介绍了dwr最常用的几个标签(转)
    用凭据管理器提升Windows7访问速度(非原创)
    IEC87005104 传输规约(国电)
  • 原文地址:https://www.cnblogs.com/hehe54321/p/8570325.html
Copyright © 2011-2022 走看看