1.聪聪可可

点分治板子

然而想那个 t1[1]*t1[2]*2+t1[0]*t1[0]想了好久

就是最基本的组合方法 毕竟(2,5)和(5,2)可是要算两次的

画画图就好了

(不要像我一样盯着大佬们的显然可得懵逼23333)

 #include<iostream>
 #include<cstdio>
 #include<cstdlib>
 #include<algorithm>
 #define maxn 40000
 using namespace std;
 struct eg
 {
     int to,v,nxt;
 }b[maxn];
 ,f[maxn],sz[maxn],vis[maxn],d[maxn]={},ans,root,sum,t1[];
 int gcd(int x,int y){return y?gcd(y,x%y):x;}
 void link(int x,int y,int z)
 {
     b[++tot].nxt=head[x];
     b[tot].to=y;
     b[tot].v=z;
     head[x]=tot;
 }
 void getroot(int u,int fa)
 {
     sz[u]=,f[u]=;
     for (int i=head[u];i;i=b[i].nxt)
     {
         int t=b[i].to;
         if (vis[t]||t==fa) continue;
         getroot(t,u);
         sz[u]+=sz[t];
         f[u]=max(f[u],sz[t]);
     }
     f[u]=max(f[u],sum-sz[u]);
     if (f[root]>f[u]) root=u;
 }
 void getdeep(int x,int fa)
 {
     t1[d[x]]++;
     for (int i=head[x];i;i=b[i].nxt)
     {
         int t=b[i].to;
         if (vis[t]||t==fa) continue;
         d[t]=(d[x]+b[i].v)%;
         getdeep(t,x);
     }
 }
 int cal(int x,int vv)
 {
     d[x]=vv%;
     t1[]=t1[]=t1[]=;
     getdeep(x,);
     ]*t1[]*+t1[]*t1[];
 }
 void work(int x)
 {
     ans+=cal(x,);
     vis[x]=;
     for (int i=head[x];i;i=b[i].nxt)
     {
         int t=b[i].to;
         if (vis[t]) continue;
         ans-=cal(t,b[i].v);
         sum=sz[t];
         root=;
         getroot(t,);
         work(root);
     }
 }
 int main()
 {
     int n;
     scanf ("%d",&n);
     ;i<n;++i)
     {
         int x,y,w;
         scanf ("%d%d%d",&x,&y,&w);
         link(x,y,w);
         link(y,x,w);
     }
     root=;f[]=n,sum=n;
     getroot(,);
     work(root);
     int l=gcd(ans,n*n);
     cout<<(ans/l)<<"/"<<(n*n/l);
     ;
 }

2.POJ1741 树上的点对

考试的时候碰到这题 感觉就像bilegou

然后我这个天大的sb就发挥我的本性打了个链剖哈哈哈哈哈哈哈哈 还没打完

考完之后老师说正解是点分治 然而考前我们是没有学过这玩意儿的(和善

去学了一下 只感觉dalao的论文写的真好

 #include<iostream>
 #include<cstdlib>
 #include<cstdio>
 #include<algorithm>
 #include<cstring>
 #define maxn 20010
 using namespace std;
 ,dep[maxn],sz[maxn],f[maxn],vis[maxn],d[maxn];
 int sum,root,n,k,ans;
 void link(int x,int y,int z)
 {
     nxt[++tot]=head[x];
     to[tot]=y;
     dis[tot]=z;
     head[x]=tot;
 }
 void gr(int x,int fa)
 {
     sz[x]=;f[x]=;
     for (int i=head[x];i;i=nxt[i])
     {
         int t=to[i];
         if (t==fa||vis[t]) continue;
         gr(t,x);
         sz[x]+=sz[t];
         f[x]=max(f[x],sz[t]);
     }
     f[x]=max(f[x],sum-sz[x]);
     if (f[root]>f[x]) root=x;
 }
 void gd(int x,int fa)
 {
     dep[++dep[]]=d[x];
     for (int i=head[x];i;i=nxt[i])
     {
         int t=to[i];
         if (t==fa||vis[t]) continue;
         d[t]=d[x]+dis[i];
         gd(t,x);
     }
 }
 int work(int x,int v)
 {
     d[x]=v;dep[]=;
     gd(x,);
     sort(dep+,dep+dep[]+);
     ;
     ,r=dep[];l<r;)
     {
         if (dep[l]+dep[r]<=k) ans+=r-l,l++;
         else r--;
     }
     return ans;
 }
 void dfs(int u)
 {
     ans+=work(u,);
     vis[u]=;
     for (int i=head[u];i;i=nxt[i])
     {
         int t=to[i];
         if (vis[t]) continue;
         ans-=work(t,dis[i]);
         sum=sz[t];
         root=;
         gr(t,);
         dfs(root);
     }
 }
 int main()
 {
     //freopen ("in.txt","r",stdin);
     //freopen ("out.txt","w",stdout);
     while (scanf ("%d%d",&n,&k))
     {
         memset(vis,,sizeof(vis));
         memset(head,,sizeof(head));
         root=,ans=,tot=;
         ) break;
         ;i<n;++i)
         {
             int x,y,z;
             scanf ("%d%d%d",&x,&y,&z);
             link(x,y,z);
             link(y,x,z);
         }
         sum=n,f[]=0x7fffffff;
         gr(,);
         dfs(root);
         cout<<ans<<endl;
     }
     ;
 }

点分治X2的更多相关文章

  1. 【教程】简易CDQ分治教程&学习笔记

    前言 辣鸡蒟蒻__stdcall终于会CDQ分治啦!       CDQ分治是我们处理各类问题的重要武器.它的优势在于可以顶替复杂的高级数据结构,而且常数比较小:缺点在于必须离线操作. CDQ分治的基 ...

  2. BZOJ 1176 [Balkan2007]Mokia ——CDQ分治

    [题目分析] 同BZOJ2683,只需要提前处理s对结果的影响即可. CDQ的思路还是很清晰的. 排序解决一维, 分治时间, 树状数组解决一维. 复杂度是两个log [代码] #include < ...

  3. 初识CDQ分治

    [BZOJ 1176:单点修改,查询子矩阵和]: 1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 200 ...

  4. BNUOJ 51279[组队活动 Large](cdq分治+FFT)

    传送门 大意:ACM校队一共有n名队员,从1到n标号,现在n名队员要组成若干支队伍,每支队伍至多有m名队员,求一共有多少种不同的组队方案.两个组队方案被视为不同的,当且仅当存在至少一名队员在两种方案中 ...

  5. 【BZOJ-4456】旅行者 分治 + 最短路

    4456: [Zjoi2016]旅行者 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 254  Solved: 162[Submit][Status] ...

  6. 【BZOJ-1176&2683】Mokia&简单题 CDQ分治

    1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1854  Solved: 821[Submit][St ...

  7. NOI题库分治算法刷题记录

    今天晚自习机房刷题,有一道题最终WA掉两组,极其不爽,晚上回家补完作业欣然搞定它,特意来写篇博文来记录下 (最想吐槽的是这个叫做分治的分类,里面的题目真的需要分治吗...) 先来说下分治法 分治法的设 ...

  8. Bzoj2683 简单题 [CDQ分治]

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1071  Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...

  9. 初学CDQ分治-NEU1702

    关于CDQ分治,首先需要明白分治的复杂度. T(n) = 2T(n/2)+O(kn), T(n) = O(knlogn) T(n) = 2T(n/2)+O(knlogn), T(n) = O(knlo ...

随机推荐

  1. jquery.uploadify+spring mvc实现上传图片

    一.前端页面 1.下载jquery.uploadify 去uploadify官网(http://www.uploadify.com/download/)下载压缩包,解压后放在如下路径: 2.html结 ...

  2. 安装 Qt 及所需 gcc 等

    嫌麻烦,下载离线安装包一次性装好 Qt 及 Qt Creator (Community) Qt 安装包下载地址 http://download.qt.io/official_releases/qt/ ...

  3. 数据结构与算法(C/C++版)【绪论/线性表】

    声明:数据结构与算法系列博文参考了<天勤高分笔记>.<王道复习指导>.C语言中文网.非商业用途,仅为学习笔记总结! 第一章<绪论> 一.基本概念及入门常识  /// ...

  4. 守护进程VS守护线程

    守护(daemon)进程 引入: join()方法可以使一个进程运行完之后再执行下一个进程,而daemon()方法就是主进程的代码执行完毕之后,不需要等待子进程,立即终止子进程. join()方法和d ...

  5. Web前端学习——CSS

    一.CSS简介CSS全称cascading style sheeding,层叠样式列表.CSS不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化.二.CSS组成1.选择器(1) ...

  6. tyvj4877 组合数

    1.组合数 (zero.cpp/c/pas) 时间限制:1s 内存限制:256MB [问题描述] 从m个不同元素中,任取n(n≤m)个元素并成一组,叫做从m个不同元素中取出n个元素的一个组合:从m个不 ...

  7. mongoDB之数据类型

    mongoDB之数据类型 Object  ID :文档的id String: 字符串,最常用,必须是utf-8 Boolean:布尔值,true 或者false Integer:整数 Double:浮 ...

  8. 深入理解 Promise

    自从ES6流行起来,Promise 的使用变得更频繁更广泛了,比如异步请求一般返回一个 Promise 对象,Generator 中 yield 后面一般跟 Promise 对象,ES7中 Async ...

  9. python入门基础

    Python 入门 变量 什么是变量?变量就是变化的量,核心是"变"和"量"两个字,变就是变化,量就是衡量状态. 为什么需要变量?程序执行的本质就是一系列状态的 ...

  10. JavaWeb核心技术学习 - 1.从JDBC说起

    作者:java1to3链接:http://www.cnblogs.com/java1to3/著作权归作者所有.未经作者本人同意,禁止一切转载.商业或非商业转载请联系作者获得授权并请注明出处. ・JDB ...