QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#863865#4799. Rotate Sum 3Wu_RenWA 12ms8016kbC++142.5kb2025-01-20 00:37:092025-01-20 00:37:23

Judging History

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

  • [2025-01-20 00:37:23]
  • 评测
  • 测评结果:WA
  • 用时:12ms
  • 内存:8016kb
  • [2025-01-20 00:37:09]
  • 提交

answer

#include <bits/stdc++.h>
typedef long double ld;
typedef long long ll;
typedef __int128 lll;
const ld eps=1e-12,pi=acosl(-1.0);
using namespace std;
struct nd{
    int x, y;
    nd operator +(const nd b)const{
        return {x+b.x,y+b.y};
    }
    nd operator -(const nd b)const{
        return {x-b.x,y-b.y};
    }
    ll operator *(const nd b)const{
        return 1ll*x*b.x+1ll*y*b.y;
    }
    void print(){
        printf("%d %d\n",x,y);
    }
}a[100010];
ld sqr(ld x){
    return x*x;
}
int n,m=0,b[200010],h[200010],cnt=0;
ll A,B,C;
ld sx,sy,L[100010],D[100010];
void add(ll a,ll b,ll c){
    // printf("%lldx + %lldy + %lld = 0\n",a,b,c);
    if(cnt==0){
        A=a,B=b,C=c;
        cnt++;
        return;
    }
    if(cnt>=2){
        // assert(fabsl(a*sx+b*sy+c)<eps);
        return;
    }
    if((lll)A*b==(lll)B*a) return;
    cnt++;
    sx=((ld)b*C-(ld)B*c)/((ld)B*a-(ld)A*b);
    sy=((ld)a*C-(ld)A*c)/((ld)A*b-(ld)B*a);
}
int main(){
    scanf("%d",&n);
    for(int i=0;i<n;i++) scanf("%d%d",&a[i].x,&a[i].y);
    for(int i=0;i<n;i++){
        b[m++]=(a[i]-a[(i-1+n)%n])*(a[(i+1)%n]-a[i]);
        b[m++]=(a[(i+1)%n]-a[i])*(a[(i+1)%n]-a[i]);
    }
    for(int i=0,p=-1,r=-1;i<m;i++){
        if(r>=i) h[i]=min(h[2*p-i],r-i+1);
        else h[i]=0;
        while(i-h[i]>=0&&i+h[i]<m&&b[i-h[i]]==b[i+h[i]]) h[i]++;
        if(i+h[i]-1>r) r=i+h[i]-1,p=i;
    }
    for(int i=0;i<m;i++) if(h[i]==min(i+1,m-i)&&h[(i+n)%m]==min((i+n)%m+1,m-(i+n)%m)){
        if(i&1){
            nd u=a[i/2],v=a[(i/2+1)%n];
            add(2ll*(v.x-u.x),2ll*(v.y-u.y),u*u-v*v);
        }
        else{
            nd u=a[i/2]+a[i/2],v=a[((i/2)-1+n)%n]+a[(i/2+1)%n];
            add(u.y-(ll)v.y,v.x-(ll)u.x,1ll*u.x*v.y/2-1ll*u.y*v.x/2);
        }
    }
    if(cnt>=2){
        ld r=0;
        for(int i=0;i<n;i++) r=max(r,sqr(a[i].x-sx)+sqr(a[i].y-sy));
        // printf("%.12Lf\n",r);
        printf("%.12Lf\n",4*sqrt(r)*r*pi/3.0);
    }
    else if(cnt==1){
        ld hx=B/sqrtl(sqr(A)+sqr(B)),hy=-A/sqrtl(sqr(A)+sqr(B)),dx=C/(A+B),dy=C/(A+B);// {(x,y) | Ax+By+C=0} = {d + lambda h | lambda}
        ld vx=-hy,vy=hx;
        for(int i=0;i<n;i++){
            L[i]=hx*a[i].x+hy*a[i].y;
            D[i]=fabsl(vx*(a[i].x-dx)+vy*(a[i].y-dy));
        }
        ld ans=0;
        for(int i=0;i<n;i++){
            ans+=(sqr(D[i])+sqr(D[(i+1)%n])+sqr((D[i]+D[(i+1)%n])/2)*4)/6*fabsl(L[i]-L[(i+1)%n]);
        }
        printf("%.12Lf\n",ans*pi/2);
    }
    else puts("0");
    // printf("%.5Lf %.5Lf\n",sx,sy);
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 8016kb

input:

3
0 -1
1 0
0 1

output:

1.047197551197

result:

ok found '1.0471976', expected '1.0471976', error '0.0000000'

Test #2:

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

input:

3
1 1
4 5
1 4

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #3:

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

input:

10
-54592357 -80406461
-54592497 -80409914
-54583785 -80448527
-54573150 -80452302
-54571418 -80445561
-54573057 -80436942
-54574710 -80428961
-54576431 -80421748
-54581146 -80413624
-54586843 -80406612

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #4:

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

input:

100
19218707 41938436
19227173 41936741
19236439 41934895
19244714 41933329
19263050 41933508
19269952 41935468
19276958 41938057
19283547 41941029
19290649 41944891
19298015 41949938
19301176 41952107
19308530 41957785
19315067 41963572
19323587 41972122
19331125 41980143
19339499 41989094
19341411...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #5:

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

input:

1000
-40710097 -68387840
-40713262 -68382547
-40715876 -68378183
-40720034 -68371279
-40724775 -68363579
-40730740 -68353973
-40736549 -68344830
-40739819 -68339713
-40742687 -68335270
-40746895 -68328767
-40752947 -68319823
-40754886 -68316968
-40761079 -68308110
-40767747 -68298732
-40770472 -6829...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #6:

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

input:

10000
84849929 -57126112
84841472 -57123352
84836897 -57121859
84827816 -57118905
84819535 -57116213
84810908 -57113420
84809250 -57112891
84802608 -57110788
84797710 -57109239
84789766 -57106738
84783187 -57104673
84773775 -57101720
84766522 -57099445
84757149 -57096507
84751370 -57094702
84745393 ...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #7:

score: 0
Accepted
time: 3ms
memory: 6192kb

input:

20000
36695920 63855096
36699821 63853995
36702135 63853342
36706473 63852120
36712051 63850550
36717151 63849119
36721923 63847781
36730794 63845294
36739373 63842890
36745062 63841296
36751484 63839501
36760104 63837093
36769910 63834359
36779620 63831652
36788710 63829118
36797797 63826588
368057...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #8:

score: 0
Accepted
time: 5ms
memory: 6352kb

input:

50000
63220612 55859143
63226689 55860975
63228549 55861536
63237384 55864204
63246036 55866818
63253128 55868961
63262941 55871927
63272384 55874783
63278109 55876515
63285718 55878817
63289955 55880101
63297340 55882339
63305978 55884958
63313100 55887118
63321418 55889645
63330759 55892485
633335...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #9:

score: 0
Accepted
time: 12ms
memory: 7580kb

input:

100000
6150629 209064536
6145207 209063168
6135217 209060644
6125551 209058201
6115985 209055782
6108484 209053885
6099150 209051524
6093683 209050141
6084620 209047848
6081814 209047138
6072408 209044758
6064213 209042684
6055932 209040588
6047114 209038356
6037530 209035930
6028054 209033531
60199...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #10:

score: 0
Accepted
time: 11ms
memory: 7916kb

input:

99989
-135597084 24675451
-135596066 24669344
-135594745 24661432
-135593849 24656066
-135593366 24653174
-135591982 24644890
-135590618 24636739
-135590005 24633076
-135588796 24625860
-135587482 24618020
-135586605 24612788
-135585381 24605487
-135583879 24596531
-135583397 24593658
-135582102 245...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #11:

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

input:

12432
-53030605 62756639
-53020643 62747841
-53011057 62739377
-53003690 62732873
-52999478 62729161
-52992709 62723198
-52986581 62717802
-52979396 62711476
-52974388 62707069
-52973366 62706172
-52970127 62703330
-52965879 62699603
-52955918 62690870
-52948653 62684509
-52940428 62677331
-52931644...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #12:

score: 0
Accepted
time: 12ms
memory: 7580kb

input:

95846
96281192 -1877350
96286947 -1871034
96291470 -1866068
96300515 -1856135
96306553 -1849500
96315540 -1839624
96320958 -1833670
96328658 -1825206
96336295 -1816811
96341317 -1811290
96348753 -1803115
96355968 -1795181
96360393 -1790315
96366306 -1783812
96372117 -1777421
96375231 -1773996
963804...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #13:

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

input:

77877
134743677 56655124
134749156 56665110
134753149 56672389
134758418 56681995
134761944 56688425
134766712 56697123
134770923 56704806
134775444 56713057
134779077 56719688
134782792 56726469
134788085 56736131
134789440 56738605
134793460 56745946
134798926 56755928
134803171 56763683
134807060...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #14:

score: 0
Accepted
time: 5ms
memory: 6676kb

input:

44722
-1000000000 -1000000000
-999999999 -999999999
-999999998 -999999996
-999999997 -999999991
-999999996 -999999984
-999999995 -999999975
-999999994 -999999964
-999999993 -999999951
-999999992 -999999936
-999999991 -999999919
-999999990 -999999900
-999999989 -999999879
-999999988 -999999856
-99999...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #15:

score: 0
Accepted
time: 5ms
memory: 6304kb

input:

30000
-999999999 -999999999
-999999997 -999999991
-999999995 -999999975
-999999993 -999999951
-999999990 -999999900
-999999989 -999999879
-999999987 -999999831
-999999984 -999999744
-999999983 -999999711
-999999982 -999999676
-999999980 -999999600
-999999979 -999999559
-999999977 -999999471
-9999999...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #16:

score: 0
Accepted
time: 4ms
memory: 6224kb

input:

23333
-1000000000 -1000000000
-999999996 -999999984
-999999994 -999999964
-999999993 -999999951
-999999992 -999999936
-999999991 -999999919
-999999986 -999999804
-999999985 -999999775
-999999983 -999999711
-999999979 -999999559
-999999977 -999999471
-999999976 -999999424
-999999975 -999999375
-99999...

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #17:

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

input:

10
-999998304 -997123584
-999995033 -975328911
-999991449 -926880399
-999989625 -892359375
-999986588 -820118256
-999985688 -795166656
-999983492 -727485936
-999982787 -703712631
-999975967 -422414911
-999964606 252735236

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #18:

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

input:

4
0 -1000000000
1 -1
2 999999999
1 0

output:

0

result:

ok found '0.0000000', expected '0.0000000', error '-0.0000000'

Test #19:

score: -100
Wrong Answer
time: 0ms
memory: 7956kb

input:

12
66207546 277078203
66231235 277049680
66236583 277045669
66270598 277030914
66302758 277017619
66330166 277008238
66376807 277002726
66421946 277004478
66139790 277216095
66150747 277172271
66169098 277129039
66185778 277105354

output:

12612135677602343703552.000000000000

result:

wrong answer 1st numbers differ - expected: '3678257734031382.0000000', found: '12612135677602343944192.0000000', error = '3428833.1354969'