QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#74272#5433. Absolute DifferenceXKErrorWA 2ms3756kbC++141.4kb2023-01-31 12:47:222023-01-31 12:47:22

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-01-31 12:47:22]
  • 评测
  • 测评结果:WA
  • 用时:2ms
  • 内存:3756kb
  • [2023-01-31 12:47:22]
  • 提交

answer

#include <bits/stdc++.h>

#define maxn 1000005
#define db double

using namespace std;

int n, m;

struct node {
	int l, r;
}a[maxn], b[maxn];

struct bd {
	int x, p;
}x[maxn];

int tot;

db sa;
db pa;
db sb;
db pb;

db asum;
db bsum;

db ans;

db ap(int len) {
	if (asum == 0) return 1.0 / n;
	return 1.0 * len / asum;
}

db bp(int len) {
	if (bsum == 0) return 1.0 / m;
	return 1.0 * len / bsum;
}

int main() {
	scanf("%d%d", &n, &m);
	for (int i = 1; i <= n; i++) {
		scanf("%d%d", &a[i].l, &a[i].r);
		x[++tot] = {a[i].l, 0};
		x[++tot] = {a[i].r, 0};
		asum += a[i].r - a[i].l;
	}
	for (int i = 1; i <= m; i++) {
		scanf("%d%d", &b[i].l, &b[i].r);
		x[++tot] = {b[i].l, 1};
		x[++tot] = {b[i].r, 1};
		bsum += b[i].r - b[i].l;
	}
	sort(x + 1, x + tot + 1, [&](bd a, bd b) {return a.x < b.x;});
	int flga = 0, flgb = 0;
	for (int i = 1; i < tot; i++) {
		if (x[i].p == 0) flga ^= 1;
		else flgb ^= 1;
		int len = x[i + 1].x - x[i].x;
		db mid = (x[i].x + x[i + 1].x) / 2.0;
		if (flga && flgb) ans += len * ap(len) * bp(len) / 3.0;
		if (flga) {
			ans += (mid * pb - sb) * ap(len);
		}
		if (flgb) {
			ans += (mid * pa - sa) * bp(len);
		}
		if (flga) {
			pa += ap(len);
			sa += ap(len) * mid;
		}
		if (flgb) {
			pb += bp(len);
			sb += bp(len) * mid;
		}
//		cout<<ans<<" "<<pa<<" "<<sa<<endl;
	}
	printf("%.12lf\n", ans);
	return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 2ms
memory: 3680kb

input:

1 1
0 1
0 1

output:

0.333333333333

result:

ok found '0.333333333', expected '0.333333333', error '0.000000000'

Test #2:

score: 0
Accepted
time: 2ms
memory: 3508kb

input:

1 1
0 1
1 1

output:

0.500000000000

result:

ok found '0.500000000', expected '0.500000000', error '0.000000000'

Test #3:

score: 0
Accepted
time: 1ms
memory: 3696kb

input:

1 1
-1000000000 1000000000
-1000000000 1000000000

output:

666666666.666666626930

result:

ok found '666666666.666666627', expected '666666666.666666627', error '0.000000000'

Test #4:

score: 0
Accepted
time: 2ms
memory: 3752kb

input:

1 1
-1000000000 0
0 1000000000

output:

1000000000.000000000000

result:

ok found '1000000000.000000000', expected '1000000000.000000000', error '0.000000000'

Test #5:

score: 0
Accepted
time: 0ms
memory: 3576kb

input:

1 1
-1000000000 -1000000000
-1000000000 1000000000

output:

1000000000.000000000000

result:

ok found '1000000000.000000000', expected '1000000000.000000000', error '0.000000000'

Test #6:

score: 0
Accepted
time: 2ms
memory: 3756kb

input:

1 1
-999999999 1000000000
-1000000000 -1000000000

output:

1000000000.499999880791

result:

ok found '1000000000.499999881', expected '1000000000.500000000', error '0.000000000'

Test #7:

score: 0
Accepted
time: 2ms
memory: 3540kb

input:

1 1
-1000000000 1000000000
-999999999 -999999999

output:

999999999.000000119209

result:

ok found '999999999.000000119', expected '999999999.000000000', error '0.000000000'

Test #8:

score: 0
Accepted
time: 2ms
memory: 3724kb

input:

1 1
1000000000 1000000000
-1000000000 -1000000000

output:

2000000000.000000000000

result:

ok found '2000000000.000000000', expected '2000000000.000000000', error '0.000000000'

Test #9:

score: 0
Accepted
time: 2ms
memory: 3552kb

input:

1000 1000
-2175 -2174
-1068 -1065
-1721 -1718
777 834
1162 1169
-3529 -3524
3966 3993
1934 1952
-234 -223
-4967 -4947
8500 8510
5272 5276
-6048 -6033
-34 -22
700 705
-7890 -7886
5538 5543
4114 4126
-9201 -9162
-1521 -1519
-5103 -5100
439 441
993 997
-1684 -1680
-8413 -8404
6724 6728
-3242 -3239
2616...

output:

6717.117145739458

result:

ok found '6717.117145739', expected '6717.117145739', error '0.000000000'

Test #10:

score: -100
Wrong Answer
time: 2ms
memory: 3736kb

input:

1000 1000
-5010 -4999
-2128 -2113
-5798 -5765
705 713
-3956 -3938
-5308 -5307
6759 6772
-772 -770
-860 -859
2308 2323
-5500 -5500
5140 5177
-6747 -6733
7509 7511
8864 8870
-6382 -6374
1901 1904
-5763 -5760
3019 3027
2962 2963
-314 -301
-222 -203
-726 -724
-62 -58
-1203 -1195
-5216 -5215
-4298 -4292
...

output:

6858.743928365629

result:

wrong answer 1st numbers differ - expected: '6682.5811275', found: '6858.7439284', error = '0.0263615'