题目描述

你需要构造一棵至少有两个顶点的树,树上的每条边有一个非负整数边权。树上两点 i,j 的距离dis(i,j) 定义为树上连接i 和j 这两点的简单路径上的边权和。

我们定义这棵树的直径为,所有满足 1≤i<jn 的  (i,j) 中, dis(i,j) 最大的。如果有多个这样的  (i,j),那么均为直径。

你需要构造一个恰有 k 个直径的树。可以证明在给定的限制下一定有解。

你构造的树需要保证 2≤n≤5000,且每条边的边权满足 50≤w≤10^5。

对于所有数据,满足 1≤k≤5000000。

Solution

构造题真是有意思…[然而本蒟蒻不会x]

构造一棵挂了三个菊花的图…

大概长这样?

我图画的还是好丑啊

我们要干一件事情我们使得每个菊花图内的每一个分叉都能和另一个菊花的任意一个分叉形成一条直径

这时候我们设左边那棵菊花的节点数为a,下面那棵的节点数为b,右边那棵的节点数为c

那么这个图的直径的数量就是ab+bc+ac

然后我们感性理解打表一下发现,a,b,c最大为1500的时候,就可以做出K的所有情况。

我好菜啊都不会构造

Code

  1. #include <bits/stdc++.h>  
  2. using namespace std;  
  3. int a,b,c,K;  
  4. int main()  
  5. {  
  6.     freopen("diameter.in","r",stdin);  
  7.     freopen("diameter.out","w",stdout);  
  8.     scanf("%d",&K);  
  9.     for (a=1;a<=1500;a++)  
  10.       for (b=a;b<=1500;b++)  
  11.         for (c=b;c<=1500;c++)  
  12.           if (a*b*1ll+b*c*1ll+a*c*1ll==K)  
  13.             goto sinian;  
  14.     a=b=c=-2;  
  15.     sinian:  
  16.     if (a==-2||K<=2000)  
  17.     {  
  18.         printf("%d\n",K+1);  
  19.         printf("1 2 2\n");  
  20.         for (int i=2;i<=K;i++)  
  21.           printf("%d %d 0\n",i,i+1);  
  22.     }  
  23.     else  
  24.     {  
  25.         printf("%d\n",a+b+c+1);  
  26.         printf("1 2 6666\n");  
  27.         printf("1 3 6666\n");  
  28.         printf("1 4 6666\n");  
  29.         --a;--b;--c;  
  30.         for (int i=5;i<a+5;i++)  
  31.           printf("2 %d 0\n",i);  
  32.         for (int i=a+5;i<a+b+5;i++)  
  33.           printf("3 %d 0\n",i);  
  34.         for (int i=a+b+5;i<a+b+c+5;i++)  
  35.           printf("4 %d 0\n",i);  
  36.     }  
  37.     return 0;  
  38. }  

FJWC2019 直径的更多相关文章

  1. fjwc2019 D2T1 直径 (构造)

    #181. 「2019冬令营提高组」直径 (这题构造题是我考场上唯一一A的题........) 先看这个特殊的Subtask4 Subtask 4(20pts):$\sqrt{1+8k}$​​​ 为整 ...

  2. DFS序+线段树 hihoCoder 1381 Little Y's Tree(树的连通块的直径和)

    题目链接 #1381 : Little Y's Tree 时间限制:24000ms 单点时限:4000ms 内存限制:512MB 描述 小Y有一棵n个节点的树,每条边都有正的边权. 小J有q个询问,每 ...

  3. 【bzoj3124】 Sdoi2013—直径

    http://www.lydsy.com/JudgeOnline/problem.php?id=3124 (题目链接) 题意 求树的直径以及直径的交. Solution 我的想法超麻烦,经供参考..思 ...

  4. poj2631 求树的直径裸题

    题目链接:http://poj.org/problem?id=2631 题意:给出一棵树的两边结点以及权重,就这条路上的最长路. 思路:求实求树的直径. 这里给出树的直径的证明: 主要是利用了反证法: ...

  5. PCB上过孔via钻孔的直径如何设置 是任意的吗 谈谈PCB钻孔工艺及规格

    PCB上过孔via钻孔的直径如何设置,是不是可以随便填入一个直径尺寸就行了?比如我的走线宽度是6mil,那我的via过孔直径也设置为6mil,节约布线空间岂不是更好?这样的设计板厂是否都能按照设计规格 ...

  6. codeforces 734E(DFS,树的直径(最长路))

    题目链接:http://codeforces.com/contest/734/problem/E 题意:有一棵黑白树,每次操作可以使一个同色连通块变色,问最少几次操作能使树变成全黑或全白. 思路:先进 ...

  7. poj1985 Cow Marathon (求树的直径)

    Cow Marathon Time Limit: 2000MS   Memory Limit: 30000K Total Submissions: 3195   Accepted: 1596 Case ...

  8. POJ1849Two[DP|树的直径](扩展HDU4003待办)

    Two Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 1390   Accepted: 701 Description Th ...

  9. VIJOS1476旅游规划[树形DP 树的直径]

    描述 W市的交通规划出现了重大问题,市政府下决心在全市的各大交通路口安排交通疏导员来疏导密集的车流.但由于人员不足,W市市长决定只在最需要安排人员的路口安放人员.具体说来,W市的交通网络十分简单,它包 ...

随机推荐

  1. MySQL 系列(二)Jdbc

    MySQL 系列(二)Jdbc 一.Jdbc 基本操作 import java.sql.Connection; import java.sql.DriverManager; import java.s ...

  2. 产品设计师 VS UX设计师:你更想成为哪一个?

    随着互联网的快速发展,越来越多的应届毕业生也成为设计师的一员.他们当中的许多人选择UX设计师作为第一份工作,也有一些人选择做一个产品设计师.你是否也想成为设计师呢?这两种设计师你更倾向于哪一个呢?在你 ...

  3. Oracle学习笔记(十)

    光标(游标)概念引入 就是一个结果集(查询或者其他操作返回的结果是多个时使用)定义一个光标 cursor c1 is select ename from emp: 从光标中取值 打开光标: --ope ...

  4. VR眼镜和AR眼镜的区别

    VR眼镜是纯虚拟的世界建模,不结合现实世界.(VR一体机和手机VR眼镜是不同的,不只是是不是以手机为载体播放器的问题,而是它们结构上也有很大的区别:另外还有一点就是电脑端VR,这个主要是游戏:http ...

  5. Codeforces768B Code For 1 2017-02-21 22:17 95人阅读 评论(0) 收藏

    B. Code For 1 time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  6. Sqlserver 密码过期时间查询

    DECLARE @login nvarchar(30) -- 查询设定密码过期的登陆账号SELECT @login = nameFROM sys.sql_loginsWHERE is_expirati ...

  7. Buffer Pool--SQL Server:Buffer Manager 对象

    --============================================================== --参考链接:http://technet.microsoft.com ...

  8. ansible常用ad hoc操作

    ansible group001 -i hosts.ip -m shell -a -v

  9. 调用kylin的restAPI接口构建cube

    调用kylin的restAPI接口构建cube 参考:http://kylin.apache.org/docs/howto/howto_build_cube_with_restapi.html 1. ...

  10. 3. Python的种类