山东省赛 传递闭包
?
https://vjudge.net/contest/311348#problem/A
思路:用floyd傳遞閉包處理點與點之間的關系,之后開數組記錄每個數字比它大的個數和小的個數,如果這個個數超過n/2那么它不可能作為中位數,其他的都有可能。
#include<bits/stdc++.h> using namespace std; int e[105][105]; int maxx[105]; int minn[105]; int main() {int t;scanf("%d",&t);while(t--){int n,m;scanf("%d%d",&n,&m);memset(e,0,sizeof(e));int flag=1;for(int i=1; i<=m; i++){int a,b;scanf("%d%d",&a,&b);if(a==b) flag=0;e[a][b]=1;}memset(maxx,0,sizeof(maxx));memset(minn,0,sizeof(minn));for(int k=1; k<=n; k++)for(int i=1; i<=n; i++)for(int j=1; j<=n; j++)e[i][j]|=e[i][k]&e[k][j];for(int i=1; i<=n; i++)for(int j=1; j<=n; j++){if(e[i][j]&&e[j][i]) flag=0;if(e[i][j]==1){maxx[j]++;minn[i]++;}}if(flag==0){for(int i=1; i<=n; i++)printf("0");if(t!=0) printf("\n");continue;}for(int i=1; i<=n; i++){if(maxx[i]>(n/2)||minn[i]>(n/2))printf("0");else printf("1");}if(t!=0) printf("\n");} }?
轉載于:https://www.cnblogs.com/dongdong25800/p/11195887.html
總結
- 上一篇: 男生做梦梦到被蛇追是什么意思
- 下一篇: 梦到看见黑白无常什么预兆