QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#516369 | #6757. 深搜 | PCTprobability | 36 | 4ms | 3988kb | C++14 | 5.4kb | 2024-08-12 16:29:58 | 2024-08-12 16:29:59 |
Judging History
answer
#include <bits/stdc++.h>
using namespace std;
#if __has_include(<atcoder/all>)
#include <atcoder/all>
using namespace atcoder;
#endif
using ll = long long;
using ld = long double;
using ull = unsigned long long;
#define endl "\n"
typedef pair<int, int> Pii;
#define REP(i, n) for (int i = 0; i < (n); ++i)
#define REP3(i, m, n) for (int i = (m); (i) < int(n); ++ (i))
#define rep(i,a,b) for(int i=(int)(a);i<(int)(b);i++)
#define ALL(x) begin(x), end(x)
#define rrep(i,a,b) for(int i=a;i>=b;i--)
#define fore(i,a) for(auto &i:a)
#define all(s) (s).begin(),(s).end()
#define drep2(i, m, n) for (int i = (m)-1; i >= (n); --i)
#define drep(i, n) drep2(i, n, 0)
#define rever(vec) reverse(vec.begin(), vec.end())
#define sor(vec) sort(vec.begin(), vec.end())
#define fi first
#define FOR_(n) for (ll _ = 0; (_) < (ll)(n); ++(_))
#define FOR(i, n) for (ll i = 0; (i) < (ll)(n); ++(i))
#define se second
#define pb push_back
#define P pair<ll,ll>
#define PQminll priority_queue<ll, vector<ll>, greater<ll>>
#define PQmaxll priority_queue<ll,vector<ll>,less<ll>>
#define PQminP priority_queue<P, vector<P>, greater<P>>
#define PQmaxP priority_queue<P,vector<P>,less<P>>
#define NP next_permutation
#define die(a) {cout<<a<<endl;return 0;}
#define dier(a) {return a;}
//const ll mod = 1000000009;
//const ll mod = 998244353;
const ll mod = 1000000007;
const ll inf = 4000000000000000000ll;
const ld eps = ld(0.00000000001);
static const long double pi = 3.141592653589793;
template<class T>void vcin(vector<T> &n){for(int i=0;i<int(n.size());i++) cin>>n[i];}
template<class T,class K>void vcin(vector<T> &n,vector<K> &m){for(int i=0;i<int(n.size());i++) cin>>n[i]>>m[i];}
template<class T>void vcout(vector<T> &n){for(int i=0;i<int(n.size());i++){cout<<n[i]<<" ";}cout<<endl;}
template<class T>void vcin(vector<vector<T>> &n){for(int i=0;i<int(n.size());i++){for(int j=0;j<int(n[i].size());j++){cin>>n[i][j];}}}
template<class T>void vcout(vector<vector<T>> &n){for(int i=0;i<int(n.size());i++){for(int j=0;j<int(n[i].size());j++){cout<<n[i][j]<<" ";}cout<<endl;}cout<<endl;}
void yes(bool a){cout<<(a?"yes":"no")<<endl;}
void YES(bool a){cout<<(a?"YES":"NO")<<endl;}
void Yes(bool a){cout<<(a?"Yes":"No")<<endl;}
void possible(bool a){ cout<<(a?"possible":"impossible")<<endl; }
void Possible(bool a){ cout<<(a?"Possible":"Impossible")<<endl; }
void POSSIBLE(bool a){ cout<<(a?"POSSIBLE":"IMPOSSIBLE")<<endl; }
#define FOR_R(i, n) for (ll i = (ll)(n)-1; (i) >= 0; --(i))
template<class T>auto min(const T& a){ return *min_element(all(a)); }
//template<class T>auto max(const T& a){ return *max_element(all(a)); }
template<class T,class F>void print(pair<T,F> a){cout<<a.fi<<" "<<a.se<<endl;}
template<class T>bool chmax(T &a,const T b) { if (a<b) { a=b; return 1; } return 0;}
template<class T>bool chmin(T &a,const T b) { if (b<a) { a=b; return 1; } return 0;}
template<class T> void ifmin(T t,T u){if(t>u){cout<<-1<<endl;}else{cout<<t<<endl;}}
template<class T> void ifmax(T t,T u){if(t>u){cout<<-1<<endl;}else{cout<<t<<endl;}}
ll fastgcd(ll u,ll v){ll shl=0;while(u&&v&&u!=v){bool eu=!(u&1);bool ev=!(v&1);if(eu&&ev){++shl;u>>=1;v>>=1;}else if(eu&&!ev){u>>=1;}else if(!eu&&ev){v>>=1;}else if(u>=v){u=(u-v)>>1;}else{ll tmp=u;u=(v-u)>>1;v=tmp;}}return !u?v<<shl:u<<shl;}
ll modPow(ll a, ll n, ll mod) { if(mod==1) return 0;ll ret = 1; ll p = a % mod; while (n) { if (n & 1) ret = ret * p % mod; p = p * p % mod; n >>= 1; } return ret; }
vector<ll> divisor(ll x){ vector<ll> ans; for(ll i = 1; i * i <= x; i++){ if(x % i == 0) {ans.push_back(i); if(i*i!=x){ ans.push_back(x / ans[i]);}}}sor(ans); return ans; }
ll pop(ll x){return __builtin_popcountll(x);}
ll poplong(ll x){ll y=-1;while(x){x/=2;y++;}return y;}
P hyou(P a){ll x=fastgcd(abs(a.fi),abs(a.se));a.fi/=x;a.se/=x;if(a.se<0){a.fi*=-1;a.se*=-1;}return a;}
P Pplus(P a,P b){ return hyou({a.fi*b.se+b.fi*a.se,a.se*b.se});}
P Ptimes(P a,ll b){ return hyou({a.fi*b,a.se});}
P Ptimes(P a,P b){ return hyou({a.fi*b.fi,a.se*b.se});}
P Pminus(P a,P b){ return hyou({a.fi*b.se-b.fi*a.se,a.se*b.se});}
P Pgyaku(P a){ return hyou({a.se,a.fi});}
void cincout(){
ios::sync_with_stdio(false);
std::cin.tie(nullptr);
cout<< fixed << setprecision(15);
}
ll p[404];
ll de[404];
vector<ll> g[404];
void dfs(ll a,ll b){
for(auto e:g[a]){
if(e==b) continue;
//cout<<"G"<<" "<<a<<" "<<e<<endl;
p[e]=a;
de[e]=de[a]+1;
dfs(e,a);
}
}
int main(){
cincout();
ll type;
cin>>type;
ll n,m,k;
cin>>n>>m>>k;
vector<ll> a(n-1),b(n-1),c(m),d(m);
for(int i=0;i<n-1;i++){
cin>>a[i]>>b[i];
a[i]--;
b[i]--;
g[a[i]].pb(b[i]);
g[b[i]].pb(a[i]);
}
for(int i=0;i<m;i++){
cin>>c[i]>>d[i];
c[i]--;
d[i]--;
}
vector<ll> x(k);
vcin(x);
for(auto &e:x) e--;
ll ans=0;
vector<vector<ll>> f(k,vector<ll>(m));
for(int i=0;i<k;i++){
p[x[i]]=x[i];
de[x[i]]=0;
dfs(x[i],-1);
for(int j=0;j<m;j++){
ll u=c[j],v=d[j];
if(de[u]<de[v]) swap(u,v);
while(de[u]!=de[v]) u=p[u];
if(u==v) f[i][j]=1;
}
}
//k 個の集合のうちいずれかに含まれることが条件
for(int i=1;i<(1<<k);i++){
vector<ll> ok(m,1);
for(int j=0;j<k;j++){
if((i>>j)&1){
for(int l=0;l<m;l++) ok[l]&=f[j][l];
}
}
ll cnt=0;
for(auto e:ok) cnt+=e;
ans+=modPow(2,cnt,mod)*(pop(i)%2?1:-1)+mod;
ans%=mod;
}
cout<<ans<<endl;
}
详细
Pretests
Final Tests
Test #1:
score: 4
Accepted
time: 0ms
memory: 3616kb
input:
1 6 6 5 5 1 2 5 6 5 3 2 6 4 1 4 1 6 4 3 4 2 6 3 2 6 5 2 6 1 3
output:
22
result:
ok 1 number(s): "22"
Test #2:
score: 4
Accepted
time: 0ms
memory: 3604kb
input:
2 6 6 6 3 1 5 3 3 2 5 4 2 6 4 6 4 2 1 4 6 1 1 2 3 4 3 4 6 2 1 5
output:
46
result:
ok 1 number(s): "46"
Test #3:
score: 4
Accepted
time: 0ms
memory: 3632kb
input:
3 6 6 6 1 2 4 1 4 6 4 5 3 5 3 6 6 2 2 3 6 5 2 5 4 2 4 6 3 2 5 1
output:
46
result:
ok 1 number(s): "46"
Test #4:
score: 4
Accepted
time: 0ms
memory: 3540kb
input:
4 15 15 6 6 1 7 1 6 11 14 7 8 11 4 8 8 10 10 12 5 10 2 12 3 8 9 11 15 5 13 2 9 4 3 14 11 12 4 14 11 4 3 5 4 5 14 5 11 5 3 10 10 4 14 10 10 6 8 15 15 10 7 4 14 10 5 8
output:
1384
result:
ok 1 number(s): "1384"
Test #5:
score: 4
Accepted
time: 0ms
memory: 3540kb
input:
5 15 15 6 11 1 9 11 1 15 7 11 15 2 6 2 4 2 8 4 4 5 14 8 1 10 7 12 6 3 10 13 14 10 5 7 5 13 3 9 13 6 6 5 4 9 4 10 15 7 15 13 12 1 11 8 10 11 11 5 6 11 13 5 3 1 4 11
output:
744
result:
ok 1 number(s): "744"
Test #6:
score: 4
Accepted
time: 0ms
memory: 3632kb
input:
6 15 15 6 9 1 7 9 6 1 7 3 6 8 8 12 4 12 12 5 10 5 10 15 14 1 3 2 11 7 13 2 10 14 14 13 5 2 15 4 8 14 4 13 12 2 6 14 6 13 3 14 10 3 4 3 3 8 9 3 11 14 10 13 4 6 3 11
output:
1873
result:
ok 1 number(s): "1873"
Test #7:
score: 4
Accepted
time: 1ms
memory: 3596kb
input:
7 300 168 6 1 184 1 41 10 41 184 18 18 215 184 271 215 267 194 184 165 18 223 18 223 83 123 165 6 165 90 83 41 2 123 40 232 194 177 232 262 123 140 271 40 211 11 271 21 18 15 11 158 177 197 1 41 35 194 110 217 177 215 121 297 123 223 38 15 72 297 46 35 212 228 140 1 89 130 11 158 296 279 35 90 287 1...
output:
144500972
result:
ok 1 number(s): "144500972"
Test #8:
score: 4
Accepted
time: 1ms
memory: 3856kb
input:
8 300 161 6 1 67 67 273 273 213 67 232 213 32 213 111 215 232 137 32 11 232 16 137 20 137 285 273 1 284 110 11 46 285 156 67 46 263 213 250 146 213 263 78 39 110 270 67 175 110 175 170 216 1 111 281 175 209 118 110 112 39 115 285 250 205 237 111 124 284 46 197 187 281 156 60 236 111 1 103 211 156 26...
output:
484515026
result:
ok 1 number(s): "484515026"
Test #9:
score: 4
Accepted
time: 0ms
memory: 3632kb
input:
9 300 157 6 56 1 1 36 56 280 285 1 285 265 166 280 56 213 87 1 191 213 87 232 166 31 280 112 43 213 43 24 293 166 232 91 31 89 259 213 232 68 134 24 168 91 280 257 172 280 87 226 229 36 56 209 239 232 43 72 72 132 265 235 283 72 300 112 1 252 112 174 241 285 24 44 8 235 193 43 256 280 168 287 257 61...
output:
644455703
result:
ok 1 number(s): "644455703"
Test #10:
score: 0
Time Limit Exceeded
input:
10 300 299 120 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50 51 51...
output:
result:
Test #11:
score: 0
Time Limit Exceeded
input:
11 300 300 116 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 50 51 51...
output:
result:
Test #12:
score: 0
Wrong Answer
time: 0ms
memory: 3764kb
input:
12 300 300 200 198 1 1 169 139 169 139 289 13 139 198 265 1 45 61 13 139 58 265 130 289 210 109 265 169 114 250 139 250 140 89 130 77 169 250 74 136 13 224 45 45 164 61 217 58 148 249 77 248 289 118 210 89 262 136 146 65 45 13 242 293 61 295 224 230 265 115 230 136 98 78 130 164 184 240 109 89 212 2...
output:
381248610
result:
wrong answer 1st numbers differ - expected: '316149672', found: '381248610'
Test #13:
score: 0
Wrong Answer
time: 3ms
memory: 3952kb
input:
13 300 300 200 1 296 1 284 1 160 296 154 109 160 160 134 175 1 134 95 184 154 198 175 184 172 10 109 248 284 51 154 10 33 134 73 181 172 172 55 33 121 218 121 225 248 205 248 91 181 282 248 154 38 218 83 188 284 243 248 225 69 221 160 65 121 154 233 269 243 287 38 154 18 175 100 147 154 23 65 154 24...
output:
50820947
result:
wrong answer 1st numbers differ - expected: '383331059', found: '50820947'
Test #14:
score: 0
Wrong Answer
time: 4ms
memory: 3716kb
input:
14 300 295 200 1 155 1 160 24 155 1 59 160 290 5 155 24 258 59 33 1 264 152 264 160 190 159 190 5 139 1 69 24 68 33 161 81 290 84 33 5 227 45 84 191 1 288 45 6 69 155 114 24 4 159 181 151 227 1 8 151 165 4 221 101 190 74 290 23 221 128 221 246 24 123 290 23 80 25 152 73 80 73 26 133 159 288 7 44 26 ...
output:
848223696
result:
wrong answer 1st numbers differ - expected: '129954782', found: '848223696'
Test #15:
score: 0
Wrong Answer
time: 4ms
memory: 3988kb
input:
15 300 299 200 1 272 1 205 238 272 170 205 272 32 32 192 243 170 59 192 170 97 205 169 86 59 252 32 4 32 40 252 50 86 289 169 59 122 289 128 3 1 32 258 289 229 289 145 3 48 97 84 41 40 35 258 238 127 48 179 129 127 9 145 50 295 243 27 177 127 292 295 170 95 295 43 218 170 55 169 278 35 81 50 155 128...
output:
275310326
result:
wrong answer 1st numbers differ - expected: '90662829', found: '275310326'
Test #16:
score: 0
Wrong Answer
time: 0ms
memory: 3772kb
input:
16 300 293 200 1 176 1 230 122 176 3 230 3 110 64 1 110 69 219 176 64 279 152 122 69 170 3 269 152 155 132 122 76 155 246 155 235 230 5 269 123 69 42 3 147 155 267 269 148 122 116 219 148 59 85 69 176 194 24 42 220 64 235 238 54 64 97 76 116 25 122 75 116 297 176 272 258 76 10 1 231 3 262 170 76 251...
output:
280167123
result:
wrong answer 1st numbers differ - expected: '693422085', found: '280167123'
Test #17:
score: 0
Runtime Error
input:
17 200000 199883 97179 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 ...
output:
result:
Test #18:
score: 0
Runtime Error
input:
18 200000 199876 97287 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 15 15 16 16 17 17 18 18 19 19 20 20 21 21 22 22 23 23 24 24 25 25 26 26 27 27 28 28 29 29 30 30 31 31 32 32 33 33 34 34 35 35 36 36 37 37 38 38 39 39 40 40 41 41 42 42 43 43 44 44 45 45 46 46 47 47 48 48 49 49 50 ...
output:
result:
Test #19:
score: 0
Runtime Error
input:
19 200000 200000 133333 1 124760 44003 124760 37294 1 163294 1 124760 4221 1 118363 163294 130356 163294 26345 150233 124760 163294 71228 118363 185064 16012 4221 136324 4221 130356 159564 16012 82836 37294 117301 37294 113319 118985 118363 67201 130356 134497 44003 118985 184508 62789 4221 167242 1...
output:
result:
Test #20:
score: 0
Runtime Error
input:
20 200000 200000 133333 140575 1 1 186893 181732 140575 79385 140575 181732 9627 186089 181732 186893 149538 186893 55018 140575 13029 186089 97797 164282 149538 18033 181732 55018 137342 1 136416 140575 148531 97797 1750 9627 9882 181032 55018 34757 55018 72967 181032 137342 70468 85420 136416 1803...
output:
result:
Test #21:
score: 0
Runtime Error
input:
21 200000 200000 133333 1 101322 88622 101322 58269 101322 58269 180983 168242 101322 95381 1 193115 95381 190995 168242 101322 148011 62879 88622 101322 172145 120738 190995 15239 120738 80271 193115 168242 21478 125310 58269 193115 93056 172145 110789 13098 172145 148011 174687 173743 190995 85181...
output:
result:
Test #22:
score: 0
Runtime Error
input:
22 200000 199999 133333 150539 1 150539 74762 1 34140 1 195593 164815 1 32085 195593 156066 32085 21074 34140 162900 34140 70220 195593 6115 32085 155396 70220 73894 150539 22486 195593 195593 19530 6115 146034 21074 40513 61074 146034 146034 198896 120389 195593 34219 61074 113107 1 195593 86095 64...
output:
result:
Test #23:
score: 0
Runtime Error
input:
23 500000 499999 333333 1 199660 284063 1 156514 199660 346277 1 199660 147381 284063 314108 147381 497971 248228 1 207371 284063 314108 165529 156514 452115 218249 248228 140112 1 395841 452115 337568 156514 314108 125202 310327 218249 446894 140112 490601 1 165529 179615 323005 207371 179615 57231...
output:
result:
Test #24:
score: 0
Runtime Error
input:
24 500000 499998 333333 65074 1 65074 304288 1 335471 59340 335471 304288 81779 81779 254965 59340 491338 108358 81779 59340 313254 59340 490077 150085 108358 304288 231400 108450 491338 108358 58590 215265 254965 14203 108450 222338 81779 313254 347805 136496 215265 173386 1 490077 183586 108358 20...
output:
result:
Test #25:
score: 0
Runtime Error
input:
25 500000 499997 333333 1 359765 359765 132729 101821 132729 1 357109 101821 393660 393660 141211 204917 1 393660 160129 204917 59682 165524 160129 359765 184850 39288 1 97240 165524 77900 101821 39288 343784 402651 1 181637 77900 351195 393660 77900 303404 357109 478493 403484 101821 357109 458913 ...