【CodeVS1076】排序

Description

给出n和n个整数,希望你从小到大给他们排序

Input

第一行一个正整数n

第二行n个用空格隔开的整数

Output

输出仅一行,从小到大输出n个用空格隔开的整数

Sample Input

3

3 1 2

Sample Output

1 2 3

Hint

1<=n<=100000

Solution

大材小用,Heap模板

 1 var
2 f:array [1..1000000] of longint;
3 a,i,n,len:longint;
4
5 procedure swap(var a,b:longint);
6 var x:longint;
7 begin
8 x:=a;a:=b;b:=x;
9 end;
10
11 procedure insert(a:longint);
12 var
13 x:longint;
14 begin
15 inc(len); f[len]:=a; x:=len;
16 while (x>>1>0) and (f[x>>1]>f[x]) do
17 begin
18 swap(f[x],f[x>>1]); x:=x>>1;
19 end;
20 end;
21
22 function get:longint;
23 var
24 x:longint;
25 begin
26 get:=f[1]; f[1]:=f[len]; dec(len); x:=1;
27 while (x<<1<=len) and ((f[x<<1]<f[x]) or (f[x]>f[x<<1+1])) do
28 begin
29 if (f[x<<1]<f[x<<1+1]) or (x<<1=len)
30 then begin swap(f[x],f[x<<1]);x:=x<<1; end
31 else begin swap(f[x],f[x<<1+1]);x:=x<<1+1; end;
32 end;
33 end;
34
35 begin
36 readln(n);
37 len:=0;
38 for i:=1 to n do
39 begin
40 read(a);
41 insert(a);
42 end;
43
44 for i:=1 to n do
45 write(get,' ');
46 writeln;
47 end.

学长写的模板

 var
a,h:array[..]of longint;
i,n,x,t,tmp:longint; procedure put(x:longint);
var
now:longint;
begin
inc(t); h[t]:=x; now:=t;
while (now<>)and(h[now]<h[now >> ]) do
begin
tmp:=h[now]; h[now]:=h[now >> ];
h[now >> ]:=tmp; now:=now >> ;
end;
end; function get:longint;
var
fa,son,now:longint;
begin
get:=h[]; h[]:=h[t]; dec(t);
fa:=;
while fa << <=t do
begin
if (fa << =t)or(h[fa << ]<h[fa << +])
then son:=fa << else son:=fa << +;
if h[son]>h[fa] then break;
tmp:=h[fa]; h[fa]:=h[son];
h[son]:=tmp; fa:=son;
end;
end; begin
readln(n);
for i:= to n do
begin read(x); put(x); end;
for i:= to n do write(get,' ');
writeln;
end.
上一篇:转帖: 一份超全超详细的 ADB 用法大全


下一篇:160405、quartz持久化所需表结构