题目描述

你需要构造一棵至少有两个顶点的树,树上的每条边有一个非负整数边权。树上两点 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. Java面向对象理解_代码块_继承_多态_抽象_接口

    面线对象: /* 成员变量和局部变量的区别? A:在类中的位置不同 成员变量:在类中方法外 局部变量:在方法定义中或者方法声明上 B:在内存中的位置不同 成员变量:在堆内存 局部变量:在栈内存 C:生 ...

  2. background image

    http://www.ajaxblender.com/bgstretcher-2-jquery-stretch-background-plugin-updated.html http://blog.d ...

  3. iOS 越狱Keynote

    [iOS Keynote] 1.2009年暴露的IKee病毒是iOS上公开的第一款蠕虫病毒,它会感染那些已经越狱并且安装了SSH,但是又没有更改其默认root密码"alpine"的 ...

  4. Linux执行YUM命令报错解决方案

    Loaded plugins: rhnplugin, security This system is not registered with RHN. RHN support will be disa ...

  5. 看图说说Sun HotSpot虚拟机对象

  6. swift 创建UICollectionView

    // //  CollectionViewController.swift //  tab // //  Created by su on 15/12/8. //  Copyright © 2015年 ...

  7. HDU1875 畅通工程再续 2017-04-12 19:52 48人阅读 评论(0) 收藏

    畅通工程再续 Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 32768/32768K (Java/Other) Total Submis ...

  8. Linux(一) - Unix&Linux 历史

    Unix Unix 的诞生 Unix的历史可以追溯到20世纪60年代中期,当时麻省理工学院,AT&T,贝尔实验室和通用电气公司联合开发了一种名为Multics的操作系统,Multics 中存在 ...

  9. C#学习(2):委托

    1.疑问: 1.委托是什么? 2.为什么需要委托? 3.委托能用来做什么? 4.如何自定义委托? 5..NET默认的委托类型有哪几种? 6.怎样使用委托? 7.多播委托是什么? 8什么是泛型委托? 9 ...

  10. 基于python 3.5 所做的找出来一个字符串中最长不重复子串算法

    功能:找出来一个字符串中最长不重复子串 def find_longest_no_repeat_substr(one_str): #定义一个列表用于存储非重复字符子串 res_list=[] #获得字符 ...