标签:输出 连通 17 题解 ll long Friends 复杂度 CF94B
简洁题意:求出任三点之间是否存在直接连通或都不连通,若存在,输出 WIN ,否则输出 FAIL
由于数据范围非常小, m<=10 ,则我们可以采用暴力枚举三个点的方式求出答案
#include<bits/stdc++.h> #define N 100010 using namespace std; typedef long long ll; ll G[17][17],m,fri,maxn,unfri; int main(){ scanf("%lld",&m); for(ll i=1;i<=m;i++){ ll from,to; scanf("%lld%lld",&from,&to); G[from][to]=G[to][from]=1; maxn=max(maxn,max(from,to)); } for(ll i=1;i<=3;i++){ for(ll j=i+1;j<=4;j++){ for(ll k=j+1;k<=5;k++){ if(i==j||i==k||j==k) continue; if((G[i][j]&&G[i][k]&&G[j][k])||(!G[i][j]&&!G[i][k]&&!G[j][k])){ puts("WIN"); return 0; } } } } puts("FAIL"); return 0; }
但是这样的复杂度是 O(n^3) ,不够优秀
考虑如果一个点入度不为 2 时,则一定有三个人满足题目条件,否则则没有
时间复杂度 O(n) ,代码就不贴了
标签:输出,连通,17,题解,ll,long,Friends,复杂度,CF94B 来源: https://www.cnblogs.com/dreamau/p/16607075.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。