第二个点T了

P2863 [USACO06JAN] The Cow Prom S

#pragma GCC diagnostic error "-std=c++11" #pragma GCC target("avx") #pragma GCC optimize(3) #pragma GCC optimize("Ofast") #pragma GCC optimize("inline") #pragma GCC optimize("-fgcse") #pragma GCC optimize("-fgcse-lm") #pragma GCC optimize("-fipa-sra") #pragma GCC optimize("-ftree-pre") #pragma GCC optimize("-ftree-vrp") #pragma GCC optimize("-fpeephole2") #pragma GCC optimize("-ffast-math") #pragma GCC optimize("-fsched-spec") #pragma GCC optimize("unroll-loops") #pragma GCC optimize("-falign-jumps") #pragma GCC optimize("-falign-loops") #pragma GCC optimize("-falign-labels") #pragma GCC optimize("-fdevirtualize") #pragma GCC optimize("-fcaller-saves") #pragma GCC optimize("-fcrossjumping") #pragma GCC optimize("-fthread-jumps") #pragma GCC optimize("-funroll-loops") #pragma GCC optimize("-fwhole-program") #pragma GCC optimize("-freorder-blocks") #pragma GCC optimize("-fschedule-insns") #pragma GCC optimize("inline-functions") #pragma GCC optimize("-ftree-tail-merge") #pragma GCC optimize("-fschedule-insns2") #pragma GCC optimize("-fstrict-aliasing") #pragma GCC optimize("-fstrict-overflow") #pragma GCC optimize("-falign-functions") #pragma GCC optimize("-fcse-skip-blocks") #pragma GCC optimize("-fcse-follow-jumps") #pragma GCC optimize("-fsched-interblock") #pragma GCC optimize("-fpartial-inlining") #pragma GCC optimize("no-stack-protector") #pragma GCC optimize("-freorder-functions") #pragma GCC optimize("-findirect-inlining") #pragma GCC optimize("-fhoist-adjacent-loads") #pragma GCC optimize("-frerun-cse-after-loop") #pragma GCC optimize("inline-small-functions") #pragma GCC optimize("-finline-small-functions") #pragma GCC optimize("-ftree-switch-conversion") #pragma GCC optimize("-foptimize-sibling-calls") #pragma GCC optimize("-fexpensive-optimizations") #pragma GCC optimize("-funsafe-loop-optimizations") #pragma GCC optimize("inline-functions-called-once") #pragma GCC optimize("-fdelete-null-pointer-checks") #pragma GCC optimize("Ofast,fast-math,unroll-loops") 试试这些加速头文件
by 灿若琉璃 @ 2019-01-30 10:00:21


过了,原来是该死用了stl的stack ```cpp #include<cstdio> #include<algorithm> #include<cstring> //#include<stack> using namespace std; const int MAXN=10010,MAXM=50010; int n,m,ans=0; int first[MAXN]; struct edge{ int u,v,next; }e[MAXM]; int tot=0; void insert(int u,int v){ tot++;e[tot].u=u;e[tot].v=v;e[tot].next=first[u];first[u]=tot; } //stack<int> s; int stack[MAXN],top=0; int deepdark=0; int dfn[MAXN]={0},low[MAXN]={0},ins[MAXN]={0}; void tarjan(int u){ dfn[u]=low[u]=++deepdark; ins[u]=1; //s.push(u); top++;stack[top]=u; for(int i=first[u];i!=-1;i=e[i].next){ int v=e[i].v; if(dfn[v]==0){ tarjan(v); low[u]=min(low[u],low[v]); } else if(ins[v]){ low[u]=min(low[u],dfn[v]); } } if(dfn[u]==low[u]){ int qwq=0; while(s.top()!=u){ ins[/*s.top()*/stack[top]]=0; //s.pop(); top--; qwq++; } ins[u]=0;//s.pop(); top--; qwq++; if(qwq>1)ans++; } } int main(){ memset(first,-1,sizeof(first)); scanf("%d%d",&n,&m); int x,y; for(int i=1;i<=m;i++){ scanf("%d%d",&x,&y); insert(x,y); } for(int i=1;i<=n;i++){ if(dfn[i]==0){ tarjan(i); } } printf("%d",ans); return 0; } ```
by Dark_Van @ 2019-01-30 10:11:30


|