cf1214E】的更多相关文章

首先定义三元组(2*i-1,2*i,d),将n个三元组按d降序排列,然后取每个三元组的2*i-1连在一起,构成一条长为n-1的链 然后降序枚举每个三元组,把对应的2*i在链上合法的位置接上, 能保证一定有解 #include<bits/stdc++.h> using namespace std; #define N 200005 struct Node{int a,b,d;}p[N]; int cmp(Node a,Node b){return a.d>b.d;} int n; vect…
题意简述:构造一棵包含2*n个节点的树,要求2*i 和 2*i-1之间的距离等于d[i]<=n 1<=i<=n 给出N和d数组,输入对应的边 题解:对d数组按照从大到小排序,然后首先构造出一条链,1 - 3 - 5 -7 --- 2*n-1 然后一次将 2 ,4  .. . 加进去,加进去的过程中维护最长的链 int d[maxn]; bool cmp(pair<int,int> x,pair<int,int> y){ return x.fi>y.fi; }…
原来这就叫构造题,了 这道题的做法,我自己诌了一个形象的名字--"挂葡萄"法( 首先,"搭葡萄架":考虑到每个距离 \(d_i\) 只与 \(2i-1,2i\) 有关,\(2i-1\) 与 \(2(i+1)-1\) 之间的距离是可以随意设置的,那不妨把所有的奇数编号串成一条链(不过注意,链上的编号不一定是按顺序的,因为要顺应题目要求的距离). 然后,"挂葡萄":将 \(d\) 数组降序排序,对于每个 \(d_i\),将其按照距离挂在 \(i+d_…