Mercurial > vba-linux
view src/win32/7zip/7z/C/Sort.c @ 1:f9f4f1b99eed
importing src directory
author | Robert McIntyre <rlm@mit.edu> |
---|---|
date | Sat, 03 Mar 2012 10:31:27 -0600 |
parents | |
children |
line wrap: on
line source
1 /* Sort.c -- Sort functions2 2008-08-173 Igor Pavlov4 Public domain */6 #include "Sort.h"8 #define HeapSortDown(p, k, size, temp) \9 { for (;;) { \10 UInt32 s = (k << 1); \11 if (s > size) break; \12 if (s < size && p[s + 1] > p[s]) s++; \13 if (temp >= p[s]) break; \14 p[k] = p[s]; k = s; \15 } p[k] = temp; }17 void HeapSort(UInt32 *p, UInt32 size)18 {19 if (size <= 1)20 return;21 p--;22 {23 UInt32 i = size / 2;24 do25 {26 UInt32 temp = p[i];27 UInt32 k = i;28 HeapSortDown(p, k, size, temp)29 }30 while (--i != 0);31 }32 /*33 do34 {35 UInt32 k = 1;36 UInt32 temp = p[size];37 p[size--] = p[1];38 HeapSortDown(p, k, size, temp)39 }40 while (size > 1);41 */42 while (size > 3)43 {44 UInt32 temp = p[size];45 UInt32 k = (p[3] > p[2]) ? 3 : 2;46 p[size--] = p[1];47 p[1] = p[k];48 HeapSortDown(p, k, size, temp)49 }50 {51 UInt32 temp = p[size];52 p[size] = p[1];53 if (size > 2 && p[2] < temp)54 {55 p[1] = p[2];56 p[2] = temp;57 }58 else59 p[1] = temp;60 }61 }63 /*64 #define HeapSortRefDown(p, vals, n, size, temp) \65 { UInt32 k = n; UInt32 val = vals[temp]; for (;;) { \66 UInt32 s = (k << 1); \67 if (s > size) break; \68 if (s < size && vals[p[s + 1]] > vals[p[s]]) s++; \69 if (val >= vals[p[s]]) break; \70 p[k] = p[s]; k = s; \71 } p[k] = temp; }73 void HeapSortRef(UInt32 *p, UInt32 *vals, UInt32 size)74 {75 if (size <= 1)76 return;77 p--;78 {79 UInt32 i = size / 2;80 do81 {82 UInt32 temp = p[i];83 HeapSortRefDown(p, vals, i, size, temp);84 }85 while (--i != 0);86 }87 do88 {89 UInt32 temp = p[size];90 p[size--] = p[1];91 HeapSortRefDown(p, vals, 1, size, temp);92 }93 while (size > 1);94 }95 */