You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
1.2 KiB
54 lines
1.2 KiB
2 years ago
|
C Copyright(C) 1999-2020 National Technology & Engineering Solutions
|
||
|
C of Sandia, LLC (NTESS). Under the terms of Contract DE-NA0003525 with
|
||
|
C NTESS, the U.S. Government retains certain rights in this software.
|
||
|
C
|
||
|
C See packages/seacas/LICENSE for details
|
||
|
|
||
|
subroutine heapsort(a,n)
|
||
|
|
||
|
dimension a(0:*)
|
||
|
integer n
|
||
|
|
||
|
integer start, bottom
|
||
|
real temp
|
||
|
|
||
|
do start = (n-2)/2, 0, -1
|
||
|
call hs_siftdown(a, start, n)
|
||
|
end do
|
||
|
|
||
|
do bottom = n-1, 1, -1
|
||
|
temp = a(0)
|
||
|
a(0) = a(bottom)
|
||
|
a(bottom) = temp
|
||
|
call hs_siftdown(a, 0, bottom)
|
||
|
end do
|
||
|
end
|
||
|
|
||
|
subroutine hs_siftdown(a, start, bottom)
|
||
|
|
||
|
real a(0:*)
|
||
|
integer start, bottom
|
||
|
integer child, root
|
||
|
real temp
|
||
|
|
||
|
root = start
|
||
|
do while(root*2 + 1 .lt. bottom)
|
||
|
child = root * 2 + 1
|
||
|
|
||
|
if ((child + 1 .lt. bottom) .and.
|
||
|
* (a(child) .lt. a(child+1))) then
|
||
|
child = child + 1
|
||
|
end if
|
||
|
|
||
|
if (a(root) .lt. a(child)) then
|
||
|
temp = a(child)
|
||
|
a(child) = a (root)
|
||
|
a(root) = temp
|
||
|
root = child
|
||
|
else
|
||
|
return
|
||
|
end if
|
||
|
end do
|
||
|
return
|
||
|
end
|