【vijos】1763 Wormhole(贪心)】的更多相关文章

https://vijos.org/p/1764 首先第一个虫洞一定是建在1号点. 证明如下: 假设一个虫洞在a,一个在b,a<b,那么走到k点的最短距离为 min{|x1-xk|, |x1-xa|+|xj-xk|},注意到|x1-xa|+|xj-xk|中的|x1-xa|是常数,而且对后一个|xj-xk|无影响,那么显然|x1-xa|取最小,即a=1 如果还没理解的我猜你没看到题目的一句话(就像我一开始一样):第二行,N个递增的整数,依次表示N个城市的坐标. 然后我们就可以枚举第二个虫洞的位置了…
本来想找一道网络流的题来着,结果这道题越看越不对劲,总觉得这题存在不用网络流的解法 看了题解区以后坚定了自己的猜想 #include <cstdio> #include <cstring> #include <algorithm> ; }; }; char map[maxN]; int N,K; int main() { scanf("%d%d",&N,&K); ;i<N;i++) { scanf("%s",…
已经是NOIP考前的最后一天了 现在在杭州的宾馆里 因为自己没带电脑 因此用ADMAN的电脑 题目描述 一维的世界就是一个数轴.这个世界的狭小我们几乎无法想象. 在这个数轴上,有N个点.从左到右依次标记为点1到N.第i个点的坐标为Xi.经过漫长时间的物理变化和化学变化,这个一维世界中产生了一个高等智慧文明,而这N个点都成为了这个文明的一座城市.而点1则成为了这个文明的首都. 出于政治上和经济上的需要,首都不能和任何城市相距太远.所以政府决定在某两个城市耗巨资修建虫洞.一个修建了虫洞的城市可以瞬移…
题目链接: https://vijos.org/p/1615 题目大意: N条路,路的高度给你,走一条路的耗费体力是从上一条路的高度到当前路高度的绝对值差. 可以改变一条路的高度,耗费的体力等于改变前后的路高度差.求最小耗费体力. 题目思路: [贪心] 其实就是求拐点,一个人先下坡在上坡要耗费两次体力,不如直接把山谷改成和两边一样高的,这样答案更优.山顶同理.最后在计算一遍换完高度之后的高度差. // //by coolxxx //#include<bits/stdc++.h> #includ…
题目传送门 传送门I 传送门II 题目大意 双栈排序,问最小字典序操作序列. 不能发现两个数$a_{j}, a_{k}\ \ (j < k)$不能放在同一个栈的充分必要条件时存在一个$i$使得$j < k < i$且$a_{i} < a_{j} < a_{k}$. 证明?写个dfs就证完了(就是考虑任意一个三元组). 然后可建图,对于满足上面条件的$(j, k)$,$j$和$k$连一条无向边. 显然必要条件时图不存在奇环,即能够二分染色. 再证明一下这是必要条件. 我们先构造…
https://vijos.org/p/1790 好神的贪心题.. 一开始我也想到了贪心,但是是错的..sad 就是因为每一个节点的编号与逆图的子树有关,且编号一定是>=子树的儿子+1的.但是想了想很快发现不可做..因为这种dfs牵扯到的东西太多了. 然后我想到这些约束是不是和差分约束有关,然后就脑补,可是后边发现这也是不可做的,因为差分约束算出来的不是编号.sad.. 无奈看题解. sad 这个和我第一个想法有关... 因为编号一定是>=逆图的子树儿子+1,显然如果每一次将编号从大向小的放是…
传送门:https://vijos.org/p/1303 背景 实中编程者联盟为了培养技术精湛的后备人才,必须从基础题開始训练. 描写叙述 某国为了防御敌国的导弹突击,研发出一种导弹拦截系统. 可是这样的导弹拦截系统有一个缺陷:尽管它的第一发炮弹可以到达随意的高度,可是以后每一发炮弹都不能高于前一发的高度. 某天,雷达捕捉到敌国的导弹来袭.因为该系统还在试验阶段,所以仅仅有一套系统,因此有可能不能拦截全部的导弹. 格式 输入格式 输入数据仅仅有一行,该行包括若干个数据,之间用半角逗号隔开.表示导…
引水入城   描述 在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N行M列的矩形,其中每个格子都代表一座城市,每座城市都有一个海拔高度. 为了使居民们都尽可能饮用到清澈的湖水,现在要在某些城市建造水利设施.水利设施有两种,分别为蓄水厂和输水站.蓄水厂的功能是利用水泵将湖泊中的水抽取到所在城市的蓄水池中.因此,只有与湖泊毗邻的第1行的城市可以建造蓄水厂.而输水站的功能则是通过输水管线利用高度落差,将湖水从高处向低处输送.故一座城市能建造输水站…
链接:Click Me! P1023Victoria的舞会3 Accepted 标签:Victoria的舞会[显示标签] 描写叙述 Victoria是一位颇有成就的艺术家,他因油画作品<我爱北京天安门>闻名于世界. 如今.他为了报答帮助他的同行们,准备开一个舞会. Victoria准备邀请n个已经确定的人,但是问题来了: 这n个人每个人都有一个小花名冊.名冊里面写着他可以通知到的人的名字.比方说在A的人名单里写了B,那么表示A可以通知到B:可是B的名单里不见的有A,也就是说B不见得通知到A.…
样例: 考试的时候没时间打了,随便敲了敲就交上去了,没想到竟然编译错误,忘定义n了23333 自己测了测能骗20分hhhh 考虑每个圆对答案的贡献,当一个圆被小圆内切的时候,分成了两半,对答案的贡献就是2.其余情况是1. 按左端点从小到大排序,左端点相同则按右端点由大到小. #include<iostream> #include<cstdio> #include<cstring> #include<algorithm> using namespace std…