FJWC2019 直径
题目描述
你需要构造一棵至少有两个顶点的树,树上的每条边有一个非负整数边权。树上两点 i,j 的距离dis(i,j) 定义为树上连接i 和j 这两点的简单路径上的边权和。
我们定义这棵树的直径为,所有满足 1≤i<j≤n 的 (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
- #include <bits/stdc++.h>
- using namespace std;
- int a,b,c,K;
- int main()
- {
- freopen("diameter.in","r",stdin);
- freopen("diameter.out","w",stdout);
- scanf("%d",&K);
- for (a=1;a<=1500;a++)
- for (b=a;b<=1500;b++)
- for (c=b;c<=1500;c++)
- if (a*b*1ll+b*c*1ll+a*c*1ll==K)
- goto sinian;
- a=b=c=-2;
- sinian:
- if (a==-2||K<=2000)
- {
- printf("%d\n",K+1);
- printf("1 2 2\n");
- for (int i=2;i<=K;i++)
- printf("%d %d 0\n",i,i+1);
- }
- else
- {
- printf("%d\n",a+b+c+1);
- printf("1 2 6666\n");
- printf("1 3 6666\n");
- printf("1 4 6666\n");
- --a;--b;--c;
- for (int i=5;i<a+5;i++)
- printf("2 %d 0\n",i);
- for (int i=a+5;i<a+b+5;i++)
- printf("3 %d 0\n",i);
- for (int i=a+b+5;i<a+b+c+5;i++)
- printf("4 %d 0\n",i);
- }
- return 0;
- }
FJWC2019 直径的更多相关文章
- fjwc2019 D2T1 直径 (构造)
#181. 「2019冬令营提高组」直径 (这题构造题是我考场上唯一一A的题........) 先看这个特殊的Subtask4 Subtask 4(20pts):$\sqrt{1+8k}$ 为整 ...
- DFS序+线段树 hihoCoder 1381 Little Y's Tree(树的连通块的直径和)
题目链接 #1381 : Little Y's Tree 时间限制:24000ms 单点时限:4000ms 内存限制:512MB 描述 小Y有一棵n个节点的树,每条边都有正的边权. 小J有q个询问,每 ...
- 【bzoj3124】 Sdoi2013—直径
http://www.lydsy.com/JudgeOnline/problem.php?id=3124 (题目链接) 题意 求树的直径以及直径的交. Solution 我的想法超麻烦,经供参考..思 ...
- poj2631 求树的直径裸题
题目链接:http://poj.org/problem?id=2631 题意:给出一棵树的两边结点以及权重,就这条路上的最长路. 思路:求实求树的直径. 这里给出树的直径的证明: 主要是利用了反证法: ...
- PCB上过孔via钻孔的直径如何设置 是任意的吗 谈谈PCB钻孔工艺及规格
PCB上过孔via钻孔的直径如何设置,是不是可以随便填入一个直径尺寸就行了?比如我的走线宽度是6mil,那我的via过孔直径也设置为6mil,节约布线空间岂不是更好?这样的设计板厂是否都能按照设计规格 ...
- codeforces 734E(DFS,树的直径(最长路))
题目链接:http://codeforces.com/contest/734/problem/E 题意:有一棵黑白树,每次操作可以使一个同色连通块变色,问最少几次操作能使树变成全黑或全白. 思路:先进 ...
- poj1985 Cow Marathon (求树的直径)
Cow Marathon Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 3195 Accepted: 1596 Case ...
- POJ1849Two[DP|树的直径](扩展HDU4003待办)
Two Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 1390 Accepted: 701 Description Th ...
- VIJOS1476旅游规划[树形DP 树的直径]
描述 W市的交通规划出现了重大问题,市政府下决心在全市的各大交通路口安排交通疏导员来疏导密集的车流.但由于人员不足,W市市长决定只在最需要安排人员的路口安放人员.具体说来,W市的交通网络十分简单,它包 ...
随机推荐
- PKUWC2019 真·游记
由于我这个大傻逼考试结果实在是没法看,所以这篇游记将尽可能略去和考试有关的内容,变成一篇真正的游记…… 接下来的内容中将会出现各种旅游攻略,寻求干货的同学可以提前左转了. Day -7 学考终于结束了 ...
- python socket编程入门(编写server实例)-乾颐堂
python 编写server的步骤: 1. 第一步是创建socket对象.调用socket构造函数.如: socket = socket.socket( family, type ) family参 ...
- [SoapUI] EndPoint不需要在配置文件中设置不同环境的值,SoapUI自带此参数的设置
在Environments里面设置就好了
- [Selenium]计算坐标进行拖拽,重写dragAndDropOffset
//@author jzhang6 public void dragAndDropOffset(WebDriver driver,WebElement dragableEl, WebElement d ...
- IntelliJ IDEA 2017版 spring-boot-devtools实现热部署
1.配置pom.xml文档 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=&qu ...
- 6、Docker Image
6.1 什么是image 文件和meta data的集合(root filesystem) 分层的,并且每一层都可以添加.改变.删除文件,成为一个新的image 不同的image可以共享相同的laye ...
- 1、Docker介绍
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化.容器完全使用沙箱机制,相互之间不会有任何接口 ...
- Android-MediaPlayer-视频频播放-异步准备
上两篇博客,Android-MediaPlayer-音频播放-普通准备,Android-MediaPlayer-音频播放-异步准备,主要是讲解了音频(.mp3文件)音乐
- Android-快速查找索引篇
01.Android-UI汇总 01.Android-TextView跑马灯效果 02.Android-Activity 01.Test 03.Android-数据存储 01.Test 04.Andr ...
- Webservice发布
此文甚好,转载自:http://blog.163.com/java_player@126/blog/static/127930738200981555021925/ 某些地方笔者已经加以改进. 使用工 ...