pku2352 Stars

平面中n个点,求每个点左下点的数量,直接上树状数组,题目数据以y为第一关键字,x为第二关键字升序排列了,所以只需从1到n依次插入横坐标,统计之前的小于当前点的横坐标的点数即可,注意树状数组上限是坐标最大值,不是n,同时坐标还有0的可能,所以都加1才行。

View Code
 1 program pku2352(input,output);
 2 var
 3    c          : array[0..40000] of longint;
 4    x,y,answer : array[0..40000] of longint;
 5    n,maxx     : longint;
 6 procedure init;
 7 var
 8    i : longint;
 9 begin
10    maxx:=0;
11    readln(n);
12    for i:=1 to n do
13    begin
14       readln(x[i],y[i]);
15       inc(x[i]);
16       if x[i]>maxx then
17      maxx:=x[i];
18    end;
19 end; { init }
20 function lowbit(x :longint ):longint;
21 begin
22    exit(x and(-x));
23 end; { lowbit }
24 procedure insect(pos,w: longint );
25 begin
26    while pos<=maxx do
27    begin
28       inc(c[pos],w);
29       pos:=pos+lowbit(pos);
30    end;
31 end; { insect }
32 function find(pos :longint ):longint;
33 begin
34    find:=0;
35    while pos>0 do
36    begin
37       inc(find,c[pos]);
38       pos:=pos-lowbit(pos);
39    end;
40 end; { find }
41 procedure main;
42 var
43    i : longint;
44 begin
45    for i:=1 to n do
46    begin
47       inc(answer[find(x[i])]);
48       insect(x[i],1);
49    end;
50 end; { main }
51 procedure print;
52 var
53    i : longint;
54 begin
55    for i:=0 to n-1 do
56       writeln(answer[i]);
57 end; { print }
58 begin
59    init;
60    main;
61    print;
62 end.
原文地址:https://www.cnblogs.com/neverforget/p/2450559.html