珍珠(bead)
题目在这个网页吔:点击打开链接
和往常一样,做题之前会胡思乱想:
1、入度和出度解决?样例可以过的嘛……可以过但好像不行Emmm……对!因为你万一只与一个点相连,但是后面的点都是一条链呢:
啊啊啊啊啊我的天哪肯定不等用入读判断!(因为“1”可以大于很多点但是他入读只有1……)
2、@#¥%……%@#¥% 2-SAT可不可以zzzzzz我是傻了吧!(陷入潜意识无法自拔)
3、旁边的TPY突然来了句弗洛伊的变形……弗洛伊德变形?哦哦!求这个图所有点的连通性,这样就可以避免该点入度与该点所大于的点数不成正相关的问题了。所以……连通的点如果大于一半,不不不,准确的说是如果大于(n+1)/2 的话,就一定不可能为中间重量的珍珠啦!嗯!写!
于是代码就出来了:
#include<bits/stdc++.h>
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<<ans;
return 0;
}
注意!必须是 " >=( n + 1 ) / 2 ",不能是" >( n + 1 ) / 2 ",留着思考嘻嘻……
还是
TPY 的一句”弗洛伊德“拯救了世界……