首页 > 其他 > 详细

一个没调好的程序

时间:2017-04-14 01:25:39      阅读:233      评论:0      收藏:0      [点我收藏+]
  1 program rrr(input,output);
  2 type
  3   treetype=record
  4      l,r,d:longint;
  5      xy,x,y,x2,s,t:int64;
  6   end;
  7 var
  8   a:array[0..400040]of treetype;
  9   x,y,s1,s2:array[0..100010]of int64;
 10   j,s,t,sx,sy,sxy,sx2:int64;
 11   n,m,i,opt,l,r:longint;
 12 procedure build(k,l,r:longint);
 13 var
 14   mid,i:longint;
 15 begin
 16    a[k].l:=l;a[k].r:=r;a[k].d:=0;a[k].s:=0;a[k].t:=0;
 17    if l=r then begin a[k].x:=x[l];a[k].y:=y[l];a[k].xy:=x[l]*y[l];a[k].x2:=x[l]*x[l];exit; end;
 18    mid:=(l+r)>>1;i:=k+k;
 19    build(i,l,mid);build(i+1,mid+1,r);
 20    a[k].x:=a[i].x+a[i+1].x;a[k].y:=a[i].y+a[i+1].y;a[k].xy:=a[i].xy+a[i+1].xy;a[k].x2:=a[i].x2+a[i+1].x2;
 21 end;
 22 procedure pushdown(k:longint);
 23 var
 24   i:longint;
 25 begin
 26    if a[k].l=a[k].r then exit;
 27    if (a[k].d=0) and (a[k].s=0) and (a[k].t=0) then exit;
 28    if a[k].d=1 then
 29       begin
 30          i:=k+k;a[i].x:=s1[a[i].r]-s1[a[i].l-1];a[i].y:=a[i].x;a[i].x2:=s2[a[i].r]-s2[a[i].l-1];a[i].xy:=a[i].x2;a[i].d:=1;a[i].s:=0;a[i].t:=0;
 31          inc(i);a[i].x:=s1[a[i].r]-s1[a[i].l-1];a[i].y:=a[i].x;a[i].x2:=s2[a[i].r]-s2[a[i].l-1];a[i].xy:=a[i].x2;a[i].d:=1;a[i].s:=0;a[i].t:=0;
 32          a[k].d:=0;
 33       end;
 34    if (a[k].s=0) and (a[k].t=0) then exit;
 35    i:=k+k;j:=a[i].r-a[i].l+1;
 36    a[i].x2:=a[i].x2+2*a[k].s*a[i].x+s*s*j;a[i].xy:=a[i].xy+a[k].s*a[i].y+a[k].t*a[i].x+s*t*j;
 37    a[i].x:=a[i].x+j*a[k].s;a[i].y:=a[i].y+j*a[k].t;inc(a[i].s,a[k].s);inc(a[i].t,a[k].t);
 38    inc(i);j:=a[i].r-a[i].l+1;
 39    a[i].x2:=a[i].x2+2*a[k].s*a[i].x+s*s*j;a[i].xy:=a[i].xy+a[k].s*a[i].y+a[k].t*a[i].x+s*t*j;
 40    a[i].x:=a[i].x+j*a[k].s;a[i].y:=a[i].y+j*a[k].t;inc(a[i].s,a[k].s);inc(a[i].t,a[k].t);
 41    a[k].s:=0;a[k].t:=0;
 42 end;
 43 procedure change1(k:longint);
 44 var
 45   mid,i:longint;
 46 begin
 47    pushdown(k);
 48    if (l<=a[k].l) and (a[k].r<=r) then
 49       begin
 50          j:=a[k].r-a[k].l+1;
 51          a[k].x2:=a[k].x2+2*s*a[k].x+s*s*j;a[k].xy:=a[k].xy+s*a[k].y+t*a[k].x+s*t*j;
 52          a[k].x:=a[k].x+j*s;a[k].y:=a[k].y+j*t;a[k].s:=s;a[k].t:=t;
 53          exit;
 54       end;
 55    mid:=(a[k].l+a[k].r)>>1;i:=k+k;
 56    if l<=mid then change1(i);
 57    if mid<r then change1(i+1);
 58    a[k].x:=a[i].x+a[i+1].x;a[k].y:=a[i].y+a[i+1].y;a[k].xy:=a[i].xy+a[i+1].xy;a[k].x2:=a[i].x2+a[i+1].x2;
 59 end;
 60 procedure change2(k:longint);
 61 var
 62   mid,i:longint;
 63 begin
 64    pushdown(k);
 65    if (l<=a[k].l) and (a[k].r<=r) then
 66       begin
 67          a[k].x:=s1[a[k].r]-s1[a[k].l-1];a[k].y:=a[k].x;a[k].x2:=s2[a[k].r]-s2[a[k].l-1];a[k].xy:=a[k].x2;a[k].d:=1;
 68          j:=a[k].r-a[k].l+1;
 69          a[k].x2:=a[k].x2+2*s*a[k].x+s*s*j;a[k].xy:=a[k].xy+s*a[k].y+t*a[k].x+s*t*j;
 70          a[k].x:=a[k].x+j*s;a[k].y:=a[k].y+j*t;a[k].s:=s;a[k].t:=t;
 71          exit;
 72       end;
 73    mid:=(a[k].l+a[k].r)>>1;i:=k+k;
 74    if l<=mid then change2(i);
 75    if mid<r then change2(i+1);
 76    a[k].x:=a[i].x+a[i+1].x;a[k].y:=a[i].y+a[i+1].y;a[k].xy:=a[i].xy+a[i+1].xy;a[k].x2:=a[i].x2+a[i+1].x2;
 77 end;
 78 procedure query(k:longint);
 79 var
 80   mid:longint;
 81 begin
 82    pushdown(k);
 83    if (l<=a[k].l) and (a[k].r<=r) then
 84       begin inc(sx,a[k].x);inc(sy,a[k].y);inc(sx2,a[k].x2);inc(sxy,a[k].xy);exit; end;
 85    mid:=(a[k].l+a[k].r)>>1;
 86    if l<=mid then query(k+k);
 87    if mid<r then query(k+k+1);
 88 end;
 89 begin
 90    assign(input,relative.in);assign(output,relative.out);reset(input);rewrite(output);
 91    readln(n,m);
 92    for i:=1 to n do read(x[i]);for i:=1 to n do read(y[i]);
 93    build(1,1,n);
 94    s1[0]:=0;s2[0]:=0;j:=0;while j<n do begin inc(j);s1[j]:=s1[j-1]+j;s2[j]:=s2[j-1]+j*j; end;
 95    for i:=1 to m do
 96       begin
 97          read(opt,l,r);
 98          if opt=1 then
 99             begin
100                sx:=0;sx2:=0;sy:=0;sxy:=0;query(1);
101                j:=r-l+1;writeln(sx, ,sy, ,sx2, ,sxy);//writeln((j*sxy-sx*sy)/(j*sx2-sx*sx):0:10);
102             end
103          else begin readln(s,t);if opt=2 then change1(1) else change2(1); end;
104       end;
105    close(input);close(output);
106 end.

 

一个没调好的程序

原文:http://www.cnblogs.com/Currier/p/6706896.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!