XJOI夏令营501-511NOIP训练14——好朋友
传送门:QAQQAQ
题意:noip2011就要来了,W校的同学们不仅看重这次比赛,更看重noip2011和谁住在同一个房间。同学之间的关系好坏可以用一个亲密值表示,亲密值越大,两个同学关系越好。小A作为W校信息组的组长,自然想要让同学们在比赛前能好好休息,放松心情,让同学们在赛场上能够超常发挥。他现在知道自己预订的房间都是双人间,且知道这n个同学之间的关系。n个同学的关系可以用一个n条双向边的连通图来描述,即某个同学只愿意和与他有边相连的同学住同一个房间,边权即为两个同学的亲密值。数据保证没有重边、自环。现在小A想知道在让所有同学的要求满足的情况下,亲密值最低的一对同学亲密值最高是多少。
思路:比赛的时候居然没想出来,打了个暴力只有30分。。。(这场比赛打炸了说)
这道题第一反应是二分,事实上只要$O(n)$贪心即可。
因为有$n$个点$n$条边,而且是个连通图,所以它是一个基环树(只有一个环),我们考虑只是一个树的情况:枚举每一个叶子结点,然后因为它们的度为1,所以只能和它们的父亲相连,然后和拓扑排序一样删边,遇到有点不能匹配或者有点匹配两次,就$No Answer$
我们就这样“拓扑排序”,剩下来没有搜到的点一定在一个环里而且这个环没有被破坏(这里需要人工YY一下),那么我们就可以对这个环进行染色,然后分两种情况求最小值即可。
代码:(强调!vector的size一定要转为int!)
#include<bits/stdc++.h>
using namespace std;
const int N=;
const int inf=(int)2e9; struct Edge{
int to,w;
Edge(){}
Edge(int to,int w) : to(to),w(w){}
};
vector<Edge> E[N];
vector<Edge> R; int F;
int n,ans=inf; int f,vis[N];
int deg[N],bl[N];
queue<int> q;
void dfs(int u,int f)
{
vis[u]=;
for(int i=;i<(int)E[u].size();i++)
{
int v=E[u][i].to;
if(v==f||bl[v]) continue;
R.push_back(E[u][i]);
if(!vis[v]) dfs(v,u);
break;
}
} int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
int x,y,W;
scanf("%d%d%d",&x,&y,&W);
E[x].push_back(Edge(y,W));
E[y].push_back(Edge(x,W));
deg[x]++; deg[y]++;
}
for(int i=;i<=n;i++)
if(deg[i]==) q.push(i);
int sum=;
while(!q.empty())
{
int u=q.front(),v=-; q.pop();
if(bl[u]) continue;
bl[u]=;
for(int i=;i<E[u].size();i++)
{
int now=E[u][i].to;//之前直接赋值为v,就算不成立下面也不会判
if(bl[now]) continue;
v=now;
ans=min(ans,E[u][i].w);
break;
}
if(v==-)
{
puts("no answer");
return ;
}
bl[v]=; sum+=;
for(int i=;i<(int)E[v].size();i++)
{
int p=E[v][i].to;
if(bl[p]) continue;
deg[p]--; if(deg[p]==) q.push(p);
}
}
if(sum==n)
{
cout<<ans<<endl;
return ;
}
for(int i=;i<=n;i++) if(!bl[i]) F=i;
dfs(F,-);
if((int)R.size()%==)
{
puts("no answer");
return ;
}
int now1=inf,now2=inf;
for(int i=;i<(int)R.size();i++)
{
if(i%==) now1=min(now1,R[i].w);//之前min写成加了
else now2=min(now2,R[i].w);
}
ans=min(ans,max(now1,now2));
cout<<ans<<endl;
return ;
}
XJOI夏令营501-511NOIP训练14——好朋友的更多相关文章
- XJOI夏令营501训练1——分配工作
传送门:QAQQAQ 题意:某公司有工作人员x1,x2,…,xn ,他们去做工作y1,y2,…,ym(n<=m) ,每个人都能做其中的几项工作,并且对每一项工作都有一个固定的效率.问能否找到一种 ...
- XJOI 夏令营501-511NOIP训练14 砍树(2)
小A是小B家的园丁.小B的家里有n棵树,第i棵树的横坐标为i.一天,小B交给小A一个任务,让他降低自己家中的某些树木的高度.这个任务对小A来说十分简单,因为他有一把极其锋利的斧头和一门独门砍树秘籍,能 ...
- test20190729 夏令营NOIP训练14
40+100+0=140. 基因光线 黑大帅统治古古怪界后,一直在玩一种很奇葩的游戏.在一个二维平面上,他先复制了n个小A,把他们放在不同的位置,然后射出一条ax+by+c=0的基因光线,宽度为d,即 ...
- XJOI 夏令营501-511NOIP训练18 高二学堂
在美丽的中山纪念中学中,有座高二学堂,同样也是因为一个人,让它们变 成了现在这个样子~那就是我们伟大的级主任.因为他,我们又迎来了一个木有电影,只有对答案的段考日:又迎来了一个不是大礼拜,而是小礼拜的 ...
- XJOI 夏令营501-511NOIP训练18 高三楼
参观完各种饭堂,学校还有什么著名的景点呢?当然是教室了,此时此刻我 们来到了高三楼.你会发现高三楼门口会有以身份认证系统,这东西还有着一段疼人的历史.每年的九月到来,高三的童鞋大多不习惯学校的作息时间 ...
- XJOI 夏令营501-511NOIP训练17 蛇形数阵
话说小X在孩提时,都会做标准的蛇形矩阵了,发现很好玩.现在的小X很想对其进行改版,变为如下类型的一个无限大蛇形数阵:令S(x)表示以1为左上角,x为右下角的矩形内所有数之和.例如S(12)就是具有深色 ...
- XJOI 夏令营501-511测试11 游戏
Alice和Bob两个人正在玩一个游戏,游戏有很多种任务,难度为p的任务(p是正整数),有1/(2^p)的概率完成并得到2^(p-1)分,如果完成不了,得0分.一开始每人都是0分,从Alice开始轮流 ...
- XJOI 夏令营501-511测试11 统计方案
小B写了一个程序,随机生成了n个正整数,分别是a[1]..a[n],他取出了其中一些数,并把它们乘起来之后模p,得到了余数c.但是没过多久,小B就忘记他选了哪些数,他想把所有可能的取数方案都找出来.你 ...
- FCN网络的训练——以SIFT-Flow 数据集为例
参考文章: http://blog.csdn.net/u013059662/article/details/52770198 caffe的安装配置,以及fcn的使用在我前边的文章当中都已经提及到了,这 ...
随机推荐
- centos WPS 字体安装
首先下载字体,解压后将整个wps_symbol_fonts目录拷贝到/usr/share/fonts目录下,然后赋予可读可执行权限. 权限设置操作如下: cd /usr/share/fonts/ ch ...
- 多线程中的detach
从 thread 对象分离执行的线程,允许执行独立地持续.一旦线程退出,则释放所有分配的资源.(就是两个线程彼此相互独立) 调用 detach 后, *this 不再占有任何线程. #include ...
- 了解GTIN小记
GTIN为条形码,即"全球贸易项目代码"(Global Trade Item Number ) GTIN用作识别商品品项的全球性独一编码,是编码系统中应用最广泛的标识代码. GTI ...
- 关于canvas绘制图像模糊问题
前段时间在做项目的裁剪并上传图像功能的时候,发现裁剪后展示的图像比较模糊,之后去百度上搜索了一下,看到有一个解决方案是设置canvas的宽高为css宽高的3倍,使用后感觉效果很好,当时就没管原理接着做 ...
- NX二次开发-UFUN遍历图层UF_LAYER_cycle_by_layer
NX11+VS2013 #include <uf.h> #include <uf_layer.h> #include <uf_ui.h> UF_initialize ...
- NX二次开发-删除功能区工具栏UF_UI_remove_ribbon
NX9+VS2012 1.打开D:\Program Files\Siemens\NX 9.0\UGII\menus\ug_main.men 找到装配和PMI,在中间加上一段 TOGGLE_BUTTON ...
- NX二次开发-NXOPEN自动切换到工程图模块
UFUN的API里是没有切换到工程图的函数的,NXOPEN里是有方法可以用的.不过应该是不支持NX9以下的版本. NX9的不能录制出来,在UI类里有方法 NX9+VS2012 #include < ...
- P1566 加等式
P1566 加等式 题目描述 对于一个整数集合,我们定义“加等式”如下:集合中的某一个元素可以表示成集合内其他元素之和.如集合{1,2,3}中就有一个加等式:3=1+2,而且3=1+2 和3=2+1是 ...
- 在360的兼容模式下关于innerHTML=“”,引发的问题
innerHTML属性,可以动态设置和修改dom,但是在360的兼容模式下回存在一些问题...... var dBody = document.body; var fatherDom = docume ...
- BOM DOM 简介
BOM和DOM简介 BOM,Browser Object Model ,浏览器对象模型. BOM主要提供了访问和操作浏览器各组件的方式. 浏览器组件: window(浏览器窗口) locati ...