标签:Poor ch 两只 Turkeys AGC016E 存活 isdigit 集合 getchar
太妙了!!
首先枚举每一只鸡,维护一个存活集合,初始化只有这只鸡。倒着考虑每一步。
- 若两只鸡都没必要存活,就忽略
- 若其中一只鸡需要存活,则另一只鸡也必须活到这一步,所以把另一只鸡也加入存活集合
- 若两只鸡都必须存活,但是肯定有一只鸡要死,所以枚举的这只鸡必死
对于两只鸡,如果它们的存活集合包含了同一只鸡,显然这只鸡只能当一次替死鬼。所以若两只鸡的存活集合没有交集,则答案加一。
\(O(nm+n^3)\)
#include<bits/stdc++.h>
using namespace std;
template<typename T>
inline void Read(T &n){
char ch; bool flag=false;
while(!isdigit(ch=getchar()))if(ch=='-')flag=true;
for(n=ch^48;isdigit(ch=getchar());n=(n<<1)+(n<<3)+(ch^48));
if(flag)n=-n;
}
enum{
MAXN = 405,
MAXM = 100005
};
char scapegoat[MAXN][MAXN], dead[MAXN];
int n, m;
struct road{int u, v;}e[MAXM];
int main(){
Read(n); Read(m);
for(register int i=1; i<=m; i++) Read(e[i].u), Read(e[i].v);
for(register int i=1; i<=n; i++){
scapegoat[i][i] = true;
for(register int j=m; j; j--){
int u = e[j].u, v = e[j].v;
if(scapegoat[i][u] and scapegoat[i][v]){
dead[i] = true;
break;
}
if(scapegoat[i][u]) scapegoat[i][v] = true;
else if(scapegoat[i][v]) scapegoat[i][u] = true;
}
}
int ans=0;
for(register int i=1; i<=n; i++) if(not dead[i])
for(register int j=i+1; j<=n; j++) if(not dead[j])
for(register int k=1; k<=n; k++){
if(scapegoat[i][k] and scapegoat[j][k]) break;
if(k==n) ans++;
}
cout<<ans<<endl;
return 0;
}
标签:Poor,ch,两只,Turkeys,AGC016E,存活,isdigit,集合,getchar 来源: https://www.cnblogs.com/oisdoaiu/p/14934082.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。