QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#290564#4050. 填树MoRanSky100 ✓482ms9020kbC++234.8kb2023-12-25 05:52:432023-12-25 05:52:45

Judging History

你现在查看的是最新测评结果

  • [2023-12-25 05:52:45]
  • 评测
  • 测评结果:100
  • 用时:482ms
  • 内存:9020kb
  • [2023-12-25 05:52:43]
  • 提交

answer

#include <bits/stdc++.h>

using namespace std;

typedef long long LL;
typedef pair<int, int> PII;

#define mp make_pair
#define pb push_back
#define fi first
#define se second

template <typename T> void inline read(T &x) {
	x = 0; int f = 1; char s = getchar();
	while (s < '0' || s > '9') { if (s == '-') { f = -1;} s = getchar(); }
	while (s >= '0' && s <= '9') x = x * 10 + (s ^ 48), s = getchar();
	x *= f;
}

template <typename T> bool inline chkMin(T &x, T y) { return y < x ? x = y, 1 : 0; }
template <typename T> bool inline chkMax(T &x, T y) { return y > x ? x = y, 1 : 0; }

const int N = 405, P = 1e9 + 7;

int n, K, L[N], R[N], d[N << 2], t, l, r, len;

vector<int> g[N];

int x[N], y[N];

int inline power(int a, int b) {
	int ret = 1;
	while (b) {
		if (b & 1) ret = 1ll * ret * a % P;
		a = 1ll * a * a % P;
		b >>= 1;
	}
	return ret;
}



struct Node{
	int w[N][2][2];
	void inline out() {
		puts("Info");
		for (int i = 1; i <= len; i++)
			cout << w[i][0] << " " << w[i][1] << endl;
		cout << endl;
	}
} ans;

void inline add(int &x, int y) {
	x += y;
	if (x >= P) x -= P;
}


int inline mod(int x) {
	return x >= P ? x - P : x;
}

int ct = 0, pr[N], sf[N], gx[N][N], i1[N], i2[N];

int inline Ip(int m, int k) {
	int ret = 0;
	sf[m + 1] = pr[0] = 1;
	for (int i = 1; i <= m; i++)
		pr[i] = 1ll * pr[i - 1] * (k - x[i] + P) % P;
	for (int i = m; i; i--)
		sf[i] = 1ll * sf[i + 1] * (k - x[i] + P) % P;
	for (int i = 1; i <= m; i++) {
		int a = 1ll * y[i] * pr[i - 1] % P * sf[i + 1] % P * i1[i - 1] % P * i2[m - i] % P;
		add(ret, a);
	}
	return ret;
}

Node operator * (const Node &a, const Node &b) {
	Node c;
	memset(c.w, 0, sizeof c.w);
	for (int i = 1; i <= len; i++) {
		for (int x = 0; x < 2; x++) {
			for (int u = 0; u < 2; u++) {
				if (!a.w[i][x][u]) continue;
				for (int y = 0; y < 2; y++) {
					for (int v = 0; v + u < 2; v++) {
						if (!b.w[i][y][v]) continue;
						add(c.w[i][x | y][u + v], 1ll * a.w[i][x][u] * b.w[i][y][v] % P);
					}
				}
			}
		}
	}
	return c;
}

void inline Add (Node &a, const Node &b) {
	for (int i = 1; i <= len; i++) {
		for (int x = 0; x < 2; x++) {
			for (int y = 0; y < 2; y++)
				add(a.w[i][x][y], b.w[i][x][y]);
		}
	}
}

Node operator + (const Node &a, const Node &b) {
	Node c;
	memset(c.w, 0, sizeof c.w);
	for (int i = 1; i <= len; i++) {
		for (int x = 0; x < 2; x++) {
			for (int y = 0; y < 2; y++) {
				c.w[i][x][y] = mod(a.w[i][x][y] + b.w[i][x][y]);
			}
		}
	}
	return c;
}


Node f[N], h[N];


void inline bd(int u) {
	for (int i = 1; i <= len; i++) {
		int x = l + i - 1;
		if (x < L[u] && x + K < R[u] && x + K >= L[u]) {
			h[u].w[i][0][0] = x + K - L[u] + 1;
			h[u].w[i][1][0] = 0;

			h[u].w[i][0][1] = 1ll * (L[u] + x + K) * (x + K - L[u] + 1) / 2 % P;
			h[u].w[i][1][1] = 0;
		} else if (L[u] <= x && x + K <= R[u]) {
			h[u].w[i][0][0] = K;
			h[u].w[i][1][0] = 1;

			h[u].w[i][0][1] = 1ll * (x + 1 + x + K) * (K) / 2 % P;
			h[u].w[i][1][1] = x;
		} else if (x >= L[u] && x <= R[u] && x + K >= R[u]) {
			h[u].w[i][0][0] = R[u] - x;
			h[u].w[i][1][0] = 1;

			h[u].w[i][0][1] = 1ll * (x + 1 + R[u]) * (R[u] - x) / 2 % P;
			h[u].w[i][1][1] = x;
		} else if (x < L[u] && x + K >= R[u]) {
			h[u].w[i][0][0] = R[u] - L[u] + 1;
			h[u].w[i][1][0] = 0;

			h[u].w[i][0][1] = 1ll * (L[u] + R[u]) * (R[u] - L[u] + 1) / 2 % P;
			h[u].w[i][1][1] = 0;
		} else {
			
		}
	}
}

void dfs(int u, int fa) {
	if (r + K < L[u] || l > R[u]) {
		for (int v: g[u]) {
			if (v == fa) continue;
			dfs(v, u);
		}
		return;
	}
	bd(u);
	int nt = 0;
	for (int v: g[u]) {
		if (v == fa) continue;
		dfs(v, u);
		++nt;
		if (nt >= 2) Add(ans, f[u] * f[v]);
		Add(f[u], f[v] * h[u]);
	}
	Add(f[u], h[u]);
	Add(ans, f[u]);
}

int rs[2];

void inline wk() {
	chkMax(l, 1);
	if (l > r) return;
	len = min(r - l + 1, n + 3);
	dfs(1, 0);
	for (int i = 0; i < 2; i++) {
		for (int j = 1; j <= len; j++)
			x[j] = l + j - 1, y[j] = ans.w[j][1][i];
		for (int j = 2; j <= len; j++) add(y[j], y[j - 1]);
		add(rs[i], Ip(len, r));
	}
	memset(ans.w, 0, sizeof ans.w);
	for (int j = 1; j <= n; j++)
		memset(f[j].w, 0, sizeof f[j].w), memset(h[j].w, 0, sizeof h[j].w);
}

int main() {
	read(n), read(K);
	i1[0] = 1, i2[0] = 1;
	for (int i = 1; i <= 2 * n; i++) {
		i1[i] = 1ll * i1[i - 1] * power(i, P - 2) % P;
		i2[i] = 1ll * i2[i - 1] * power(P - i, P - 2) % P;
	}
	for (int i = 1; i <= n; i++) {
		read(L[i]), read(R[i]);
		d[++t] = L[i];
		d[++t] = R[i] + 1;
		d[++t] = L[i] - K;
		d[++t] = R[i] + 1 - K;
	}
	for (int i = 1; i < n; i++) {
		int u, v; read(u), read(v);
		g[u].pb(v), g[v].pb(u);
	}
	sort(d + 1, d + 1 + t);
	t = unique(d + 1, d + 1 + t) - d - 1;
	for (int i = 1; i < t; i++)
		l = d[i], r = d[i + 1] - 1, wk();
	printf("%d\n%d\n", rs[0], rs[1]);
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 10
Accepted
time: 1ms
memory: 3892kb

input:

5 1
3 6
5 6
1 8
1 4
3 6
2 1
3 2
4 1
5 2

output:

89
1035

result:

points 1.0 Right Answer!

Test #2:

score: 10
Accepted
time: 4ms
memory: 6356kb

input:

30 137096004
215692601 593148870
587744254 908728660
354367633 568826817
376073684 818829717
535492238 780479755
232775004 650109673
251965857 701073037
143963540 496974493
55915221 744763438
528234065 732528154
332418107 641577253
13159384 780093251
179253217 905083657
430741053 697503733
87499240 ...

output:

354648863
631656809

result:

points 1.0 Right Answer!

Test #3:

score: 10
Accepted
time: 3ms
memory: 4260kb

input:

30 250086104
591069936 968891212
41581360 609904362
262819200 944260403
535918368 583285015
263875027 793847733
138437402 676792228
597402197 736836166
438565277 486906152
342827909 610036059
328767032 512083092
437385632 703793342
523490836 570259000
325460973 781713097
202545410 819125374
49381546...

output:

712687176
206651743

result:

points 1.0 Right Answer!

Test #4:

score: 10
Accepted
time: 0ms
memory: 4228kb

input:

30 143
177 217
32 208
209 318
152 463
187 385
160 475
43 346
163 273
2 426
219 267
191 455
210 246
102 483
130 257
194 378
256 370
279 347
220 351
56 333
192 387
167 254
85 211
292 437
180 492
111 390
285 478
297 428
43 414
182 296
126 374
2 1
3 2
4 2
5 2
6 4
7 1
8 3
9 2
10 6
11 7
12 6
13 3
14 8
15 ...

output:

362561768
493898850

result:

points 1.0 Right Answer!

Test #5:

score: 10
Accepted
time: 349ms
memory: 8792kb

input:

200 67630
117218 161430
70358 166290
26412 193532
66149 121289
92339 117825
64209 152682
48781 183530
86224 186305
51599 143557
46140 191874
42871 88142
50177 123036
43200 105591
19016 97454
70014 147624
6141 197253
85275 198926
115374 134032
52355 119685
12417 193878
6361 169371
86153 180522
61286 ...

output:

158279748
290430672

result:

points 1.0 Right Answer!

Test #6:

score: 10
Accepted
time: 283ms
memory: 8344kb

input:

200 19198
21280 117277
90662 123986
45289 179202
63408 136645
46256 98728
117947 166570
55778 175190
89589 103669
119147 182875
5585 91771
68300 145843
70733 109963
61418 157603
63596 164653
81734 110752
109084 137376
95705 166924
589 133255
73046 114963
87681 194475
74593 179939
102071 116794
28707...

output:

584166745
705498146

result:

points 1.0 Right Answer!

Test #7:

score: 10
Accepted
time: 423ms
memory: 9020kb

input:

200 216054723
443948382 766438713
468188882 870457165
68166269 745871349
537369301 978917205
328904568 676155793
511075340 824468057
93969870 635291060
303629013 656508336
420101343 832868347
259545478 517757019
593962769 912428239
256177328 983461740
115320903 852333642
279416317 719120507
47587791...

output:

93827485
825656833

result:

points 1.0 Right Answer!

Test #8:

score: 10
Accepted
time: 369ms
memory: 8544kb

input:

200 69033242
285053641 976355712
227553452 938314736
107179948 750434085
303626071 690497167
439733858 799894196
113776149 659462530
121522752 575933362
418433076 542866700
567079971 780647210
183890864 824783214
380023995 846912184
71118369 969692168
262487491 849298427
90348662 619018202
251961261...

output:

712593509
913113589

result:

points 1.0 Right Answer!

Test #9:

score: 10
Accepted
time: 482ms
memory: 8140kb

input:

200 238518392
537484342 867288829
375663129 568281320
68193346 485121003
404605326 952659797
101768795 715315465
233224149 568371067
144921013 840998588
181380439 865915297
197203040 508386871
557417302 592025048
12752815 704019284
72698900 677587957
370489735 950055609
583359215 939650067
359418111...

output:

166999279
732641046

result:

points 1.0 Right Answer!

Test #10:

score: 10
Accepted
time: 456ms
memory: 8364kb

input:

200 239255629
523317820 588402780
280886988 468771488
496202333 677770342
572534106 822314012
398157554 674960423
590860104 791274038
547846359 984625596
348890270 852572492
79439545 521421058
338618714 733050443
520589139 848284325
226194319 568526848
536193964 654742253
86493140 959602843
53836008...

output:

560344075
299371604

result:

points 1.0 Right Answer!

Extra Test:

score: 0
Extra Test Passed