一道提高组的题。。。。。

传送门:题目在这里。。。。

现在都懒得更自己的blog了,怕是太颓废了_ (:з」∠) _

好久没做题了,手都生了。(好吧其实是做题方面手太生了)

这题我都不想讲了,把代码一贴就算了呗。。

但还是要说说的。。。。

首先,题目里说:“无向连通图G 有n 个点,n - 1 条边。”

我们可以知道这是一棵树(怕不是废话。。),这样遍历的时候就能保证是O(n)级别了。。

找最大值 很简单,遍历树的时候找一下与每个点相连的点的最大值和次大值一乘就完了。。。显然这么贪心是没问题的。。。

求和 稍微麻烦一点,但也没多麻烦。。

然后呢,“对于图G 上的点对( u, v) ,若它们的距离为2 ”

这就分为两种情况。。。

我们假定以1为根(这样就能分出父子关系),与x距离为2就分为x和x的祖父和x和x的兄弟两种。。

x和x的祖父的联合权值好算(因为只有一个),遍历的时候记录一下父亲然后查一下就完了。

x和x的兄弟稍微麻烦一点,聪明的人是不会一个一个算的,因为这样会是O(n²)级别的。

这就要搬出一个公式来了,(不知道怎么想到这一点的。。但是正确性不言而喻,不信可以自己推推。。)

\[\sum_{i=L}^{R}\sum_{j=i+1}^{R}a_i*a_j=\frac{(\sum_{i=L}^{R}a_i)^2-\sum_{i=L}^{R}a_i^2}{2}
\]

其实就是这个意思(我拿3个点举个例子吧~)

有3个点abc我们要求ab+ac+bc的时候,我们可以求出a+b+c①和a²+b²+c²②,然后(①²-②)/2即得。。

这个和和平方和我们是可以在能接受的时间内算出的。。

以上加起来就得到了代码。。我用bfs写的。。不过建议你们用dfs写就行了(这又不是会爆栈的什么省选)

然后题目说的是 “有序点对”(说明里就能看出来) 所以ans最后要2。。。(2后记得再取一次模不然会被卡到50)

然后就是最大值不用取模而求和需要取模(语文问题),这样用代码实现就可以AC啦(≧▽≦)/

然后这次的程序我是用QtCreator写的(Windows啦)。。。。(好像还配置了半天,调试器还没弄好)个人感觉界面很友好。。字体看着非常顺眼,补全也挺贴心的。。似乎也不像vs毛病特别多。。

(但换一个IDE就要换一下编译运行的快捷键也是很醉)

以上一段算是广告(当然没有广告费)纯属给大家安利一下,没有任何卵用,并不重要。。

我们上代码吧。。

  1. #include <cstdio>
  2. #include <queue>
  3. using std::queue;
  4. queue<int> q;
  5. const int p=10007;
  6. const int N=200020;
  7. struct edge{
  8. int to,next;
  9. };
  10. edge e[N<<1]; int v[N],tot=0;
  11. int fa[N],w[N];
  12. bool vis[N];
  13. int ans=0,maxn=0;
  14. inline int max(const int &a,const int &b){
  15. if(a<b) return b; return a;
  16. }
  17. inline int getnum(){
  18. int a=0;char c=getchar();bool f=0;
  19. for(;(c<'0'||c>'9')&&c!='-';c=getchar());
  20. if(c=='-') c=getchar(),f=1;
  21. for(;c>='0'&&c<='9';c=getchar()) a=(a<<1)+(a<<3)+c-'0';
  22. if(f) return -a; return a;
  23. }
  24. void build(int from, int to){
  25. e[++tot].to=to; e[tot].next=v[from]; v[from]=tot;
  26. }
  27. void bfs(){
  28. while (!q.empty()) {
  29. int x=q.front(); q.pop(); vis[x]=1;
  30. long long numa=0,numb=0;
  31. int mx1=0,mx2=0;
  32. ans=(ans+w[x]*w[fa[fa[x]]])%p;
  33. for(int i=v[x];i;i=e[i].next){
  34. int y=e[i].to;
  35. if(w[y]>mx1) mx2=mx1,mx1=w[y];
  36. else mx2=max(mx2,w[y]);
  37. if(!vis[y]){
  38. q.push(y); fa[y]=x;
  39. numa+=w[y]; numb+=w[y]*w[y];
  40. }
  41. }
  42. long long _=(numa*numa-numb)>>1;
  43. ans=(ans+_)%p;
  44. maxn=max(maxn,mx1*mx2);
  45. }
  46. }
  47. int main(){
  48. int n=getnum();
  49. for(int i=1;i<n;i++){
  50. int a=getnum(),b=getnum();
  51. build(a,b); build(b,a);
  52. }
  53. for(int i=1;i<=n;i++) w[i]=getnum();
  54. q.push(1); bfs();
  55. printf("%d %d",maxn,(ans<<1)%p);
  56. }

唔 就是这样。。

TG组的题对我来说还是太难了。。

我还是太弱了。。

【学术篇】luogu1351 [NOIP2014提高组] 联合权值的更多相关文章

  1. NOIP2014提高组 联合权值(距离为2的树形dp)

    联合权值 题目描述 无向连通图 GG 有 nn 个点,n-1n−1 条边.点从 11 到 nn 依次编号,编号为 ii 的点的权值为 W_iWi​,每条边的长度均为 11.图上两点 (u, v)(u, ...

  2. [NOIP2014提高组]联合权值

    题目:洛谷P1351.Vijos P1906.codevs3728.UOJ#16. 题目大意:有一个无向连通图,有n个点n-1条边,每个点有一个权值$W_i$,每条边长度为1.规定两个距离为2的点i和 ...

  3. [NOIp2014] luogu P1351 联合权值

    哎我博 4 了. 题目描述 无向连通图 GGG 有 nnn 个点,n−1n−1n−1 条边.点从 111 到 nnn 依次编号,编号为 iii 的点的权值为 WiW_iWi​,每条边的长度均为 111 ...

  4. [NOIP2014] 提高组 洛谷P1351 联合权值

    题目描述 无向连通图G 有n 个点,n - 1 条边.点从1 到n 依次编号,编号为 i 的点的权值为W i ,每条边的长度均为1 .图上两点( u , v ) 的距离定义为u 点到v 点的最短距离. ...

  5. Noip2014 提高组 T2 联合权值 连通图+技巧

    联合权值 描述 无向连通图 G 有 n 个点,n-1 条边.点从 1 到 n 依次编号,编号为 i 的点的权值为 WiWi, 每条边的长度均为 1.图上两点(u, v)的距离定义为 u 点到 v 点的 ...

  6. NOIP2014提高组第二题联合权值

    还是先看题吧: 试题描述  无向连通图 G 有 n 个点,n-1 条边.点从 1 到 n 依次编号,编号为 i 的点的权值为 Wi ,每条边的长度均为 1.图上两点(u, v)的距离定义为 u 点到 ...

  7. 【NOIP2014提高组】联合权值

    https://www.luogu.org/problem/show?pid=1351 既然是一棵树,就先转化成有根树.有根树上距离为2的点对,路径可能长下面这样: 枚举路径上的中间点X. 第一种情况 ...

  8. NOIP 提高组 2014 联合权值(图论???)

    传送门 https://www.cnblogs.com/violet-acmer/p/9937201.html 题解: 相关变量解释: int n; int fa[maxn];//fa[i] : i的 ...

  9. 题解【luoguP1351 NOIp提高组2014 联合权值】

    题目链接 题意:给定一个无根树,每个点有一个权值.若两个点 \(i,j\) 之间距离为\(2\),则有联合权值 \(w_i \times w_j\).求所有的联合权值的和与最大值 分析: 暴力求,每个 ...

随机推荐

  1. UVA 10242 Fourth Point

    题意:给你平行四边形两条边的顶点,让你求第四个点. 思路:要找到俩边的公共点,然后向量运算. AC代码: #include<cstdio> #include<cmath> #i ...

  2. MFS分布式文件系统【3】存储节点 CHUNK SERVER 部署

    [root@ky_hs_252 mfs-1.6.27]# mkdir /usr/local/mfs [root@ky_hs_252 mfs-1.6.27]# useradd mfs -s /sbin/ ...

  3. 高级UI晋升之常用View(三)下篇

    更多Android高级架构进阶视频学习请点击:https://space.bilibili.com/474380680本篇文章将从WebView来介绍常用View: 一.WebView介绍 Andro ...

  4. mysql(自动添加系统时间)timestamp类型字段的CURRENT_TIMESTAMP与ON UPDATE CURRENT_TIMESTAMP属性

    timestamp有两个属性,分别是CURRENT_TIMESTAMP 和ON UPDATE CURRENT_TIMESTAMP两种,使用情况分别如下: 1.CURRENT_TIMESTAMP 当要向 ...

  5. erlang在windows下和虚拟机节点通信

    版权声明:博客将逐步迁移到 http://cwqqq.com https://blog.csdn.net/cwqcwk1/article/details/24738599 在Linux下部署erlan ...

  6. undefined reference to `TTF_Init'

    如果编译时遇上 undefined reference to `FunctionName' 或是这种类似错误,首先就得检查是不是函数名拼写错误,如果不是,那估计是编译时候有些链接库没加进去 比如这篇上 ...

  7. C static extern和全局变量

    #include <stdio.h> //默认全局变量为外部变量 int a; //当全局变量前面加上static时,该变量为内部变量 static int b; void test(); ...

  8. 结对编程项目报告--四则运算CORE

    <!doctype html> sw_lab2.mdhtml {overflow-x: initial !important;}#write, body { height: auto; } ...

  9. 用sql语句合并工作表

    Sub 工作表合并() f = Application.GetOpenFilename(filefilter:="excel文件,*xlsx", Title:="请选择文 ...

  10. [转载]A星寻路算法介绍

    转载自:http://www.raywenderlich.com/zh-hans/21503/a%E6%98%9F%E5%AF%BB%E8%B7%AF%E7%AE%97%E6%B3%95%E4%BB% ...