https://nanti.jisuanke.com/t/A1725node
V&Vios
無向圖oop
強連通圖測試
每一個子圖,n個點,選擇n-1條,使互相鏈接優化
由於目標點x->點y,能夠改成點y->點xspa
V&Ccode
弱連通圖(將有向圖的全部的有向邊替換爲無向邊,所獲得的圖稱爲原圖的基圖。若是一個有向圖的基圖是連通圖,則有向圖是弱連通圖。)blog
1.一個弱連通子圖,它裏面的點與該弱連通子圖外的點與沒有關係,能夠單獨處理排序
2.弱連通子圖裏,一個點,必有另外點與之相鄰,包括入和出ci
3.若弱連通子圖裏有環,則不管怎麼修改,避免不了最後的圖,有環的狀況(由於需求沒法改變,x指向y,則從x出發,必有路徑到y),
對於環外剩下的點,也必至少有一條邊,總邊數大於等於點數
4.對於弱連通子圖的點,能夠構造一個環,使它們相互能夠到達,須要的邊的數量爲點數
5.因此對於有環的弱連通子圖,選擇4的方案,構造環
6.對於沒有環的弱連通子圖,求拓撲排序,從小到大賦予編號,
按照編號,點1鏈接,點2鏈接點3,...,點p-1鏈接點p,知足條件。
對於邊,一定是編號小的點鏈接編號大的點,因此沒有產生遺漏。
須要的邊的數量爲點數-1
如
6
Constant 1 2 3 1 2 3
Variable 4 4 4 5 5 5
計蒜客好像不能開如下優化,差評:
ios_base::sync_with_stdio(0);
cin.tie(0);
///因此參加比賽時,先測試一下這些能不能用
1 #include <cstdio> 2 #include <cstdlib> 3 #include <cmath> 4 #include <cstring> 5 #include <string> 6 #include <algorithm> 7 #include <iostream> 8 using namespace std; 9 #define ll long long 10 #include <map> 11 12 const double eps=1e-8; 13 const ll inf=1e9; 14 const ll mod=1e9+7; 15 const int maxn=1e5+10; 16 17 struct node 18 { 19 int d; 20 node *to; 21 }*e[maxn],*b[maxn]; 22 23 string c[2]; 24 int s[2][maxn],tot[maxn],q[maxn]; 25 bool vis[maxn]; 26 27 map<pair<int,int>,int> ma; 28 29 int main() 30 { 31 // ios_base::sync_with_stdio(0); 32 // cin.tie(0); 33 34 node *p; 35 int n,i,j,k,x,y,cnt=0; 36 int head,tail,d,temp; 37 scanf("%d",&n); 38 k=0; 39 for (j=0;j<2;j++) 40 { 41 cin>>c[j]; 42 if (j==0 && c[0][0]=='C') 43 k=1; 44 45 for (i=1;i<=n;i++) 46 cin>>s[j^k][i]; 47 } 48 if (k==1) 49 swap(c[0],c[1]); 50 51 if (c[0][0]=='C' && c[1][0]=='C') 52 { 53 for (i=1;i<=n;i++) 54 if (s[0][i]!=s[1][i]) 55 break; 56 if (i==n+1) 57 cout<<0; 58 else 59 cout<<-1; 60 } 61 else if (c[1][0]=='C') 62 { 63 for (i=1;i<=n;i++) 64 { 65 x=s[0][i]; 66 y=s[1][i]; 67 if (x==y || ma.find({x,y})!=ma.end()) 68 continue; 69 ma[{x,y}]=1; 70 p=new node(); 71 p->d=y; 72 p->to=e[x]; 73 e[x]=p; 74 75 p=new node(); 76 p->d=x; 77 p->to=e[y]; 78 e[y]=p; 79 tot[y]++; 80 81 p=new node(); 82 p->d=y; 83 p->to=b[x]; 84 b[x]=p; 85 86 } 87 88 for (i=1;i<=1e5;i++) 89 if (!vis[i] && e[i]) 90 { 91 q[1]=i; 92 vis[i]=1; 93 head=0,tail=1; 94 while (head<tail) 95 { 96 d=q[++head]; 97 p=e[d]; 98 while (p) 99 { 100 if (!vis[p->d]) 101 { 102 vis[p->d]=1; 103 q[++tail]=p->d; 104 } 105 p=p->to; 106 } 107 } 108 109 temp=tail; 110 head=0,tail=0; 111 for (j=1;j<=temp;j++) 112 if (!tot[q[j]]) 113 q[++tail]=q[j]; 114 115 ///if no loop, traversal tail points 116 while (head<tail) 117 { 118 head++; 119 d=q[head]; 120 p=b[d];/// 121 while (p) 122 { 123 tot[p->d]--; 124 if (!tot[p->d]) 125 q[++tail]=p->d; 126 p=p->to; 127 } 128 } 129 cnt+=temp-(tail==temp); 130 } 131 cout<<cnt; 132 } 133 else 134 { 135 for (i=1;i<=n;i++) 136 { 137 x=s[0][i]; 138 y=s[1][i]; 139 if (x==y) 140 continue; 141 p=new node(); 142 p->d=y; 143 p->to=e[x]; 144 e[x]=p; 145 146 p=new node(); 147 p->d=x; 148 p->to=e[y]; 149 e[y]=p; 150 } 151 152 for (i=1;i<=1e5;i++) 153 if (!vis[i] && e[i]) 154 { 155 q[1]=i; 156 vis[i]=1; 157 head=0,tail=1; 158 while (head<tail) 159 { 160 d=q[++head]; 161 p=e[d]; 162 while (p) 163 { 164 if (!vis[p->d]) 165 { 166 vis[p->d]=1; 167 q[++tail]=p->d; 168 } 169 p=p->to; 170 } 171 } 172 cnt+=tail-1; 173 } 174 cout<<cnt; 175 } 176 return 0; 177 } 178 /* 179 2 180 Constant 111 222 181 Constant 111 223 182 183 2 184 Constant 111 222 185 Constant 111 222 186 187 5 188 Variable 111 222 333 444 555 189 Variable 222 333 111 444 666 190 191 5 192 Constant 111 222 333 444 333 193 Variable 222 111 444 555 666 194 195 5 196 Variable 222 111 444 555 666 197 Constant 111 222 333 444 333 198 199 7 200 Variable 222 111 444 555 666 444 444 201 Constant 111 222 333 444 333 666 555 202 203 3 204 Variable 111 111 111 205 Variable 222 222 222 206 207 4 208 Constant 333 111 111 111 209 Variable 333 222 222 222 210 211 6 212 Constant 1 2 3 1 2 3 213 Variable 4 4 4 5 5 5 214 215 6 216 Variable 1 2 3 1 2 3 217 Variable 4 4 4 5 5 5 218 219 3 220 Variable 1 2 3 221 Variable 4 5 6 222 223 3 224 Constant 1 2 3 225 Variable 4 5 6 226 */