信息学奥赛一本通 珍珠

 珍珠bead)

题目在这个网页吔:点击打开链接

和往常一样,做题之前会胡思乱想:
1、入度和出度解决?样例可以过的嘛……可以过但好像不行Emmm……对!因为你万一只与一个点相连,但是后面的点都是一条链呢:
信息学奥赛一本通 珍珠_第1张图片
啊啊啊啊啊我的天哪肯定不等用入读判断!(因为“1”可以大于很多点但是他入读只有1……)

2、@#¥%……%@#¥% 2-SAT可不可以zzzzzz我是傻了吧!(陷入潜意识无法自拔)
3、旁边的TPY突然来了句弗洛伊的变形……弗洛伊德变形?哦哦!求这个图所有点的连通性,这样就可以避免该点入度与该点所大于的点数不成正相关的问题了。所以……连通的点如果大于一半,不不不,准确的说是如果大于(n+1)/2 的话,就一定不可能为中间重量的珍珠啦!嗯!写!

于是代码就出来了:

#include
using namespace std;
const int N=10000+5;
int n,m,ans1,ans2,ans,a,b;
bool dis1[N][N],dis2[N][N];
int main(){
	cin>>n>>m;
	
	for(int i=1;i<=m;i++){
		cin>>a>>b;
		dis1[a][b]=dis2[b][a]=true;
	}
	
	for(int k=1;k<=n;k++)
	    for(int j=1;j<=n;j++)
	        for(int i=1;i<=n;i++)
	            if(j!=k && j!=i && i!=k){
	                dis1[i][j] = dis1[i][j] || (dis1[i][k] && dis1[k][j]);
					dis2[i][j] = dis2[i][j] || (dis2[i][k] && dis2[k][j]);
				}
	
	for(int i=1;i<=n;i++){
		ans1=ans2=0;
		for(int j=1;j<=n;j++)
		    if(dis1[i][j])
				ans1++;
		for(int j=1;j<=n;j++)
		    if(dis2[i][j])
		    	ans2++;
		if(ans1>=(n+1)/2 || ans2>=(n+1)/2)
		    ans++;
	}
	
	cout<

注意!必须是 " >=( n + 1 ) / 2 ",不能是" >( n + 1 ) / 2 ",留着思考嘻嘻……

还是  TPY 的一句”弗洛伊德“拯救了世界……

你可能感兴趣的:(算法经典之图论)