2020-02-16 00:35:54 +00:00
|
|
|
U0 QuickSortI64(I64 *base,I64 num, I64 (*fp_compare)(I64 e1,I64 e2))
|
2020-02-15 20:01:48 +00:00
|
|
|
{/*Quick Sort for width==8.
|
|
|
|
fp_compare() passes by value instead of ref.
|
|
|
|
|
2020-02-16 03:32:01 +00:00
|
|
|
For ascending strings: return StrCompare(e1,e2);
|
2020-02-15 20:01:48 +00:00
|
|
|
For ascending ints : return e1-e2;
|
|
|
|
|
2020-02-16 04:57:03 +00:00
|
|
|
Maybe, look at $LK,"::/Demo/MultiCore/MPRadix.CC"$.
|
2020-02-15 20:01:48 +00:00
|
|
|
*/
|
|
|
|
I64 i,*left,*right,pivot;
|
|
|
|
if (num>1) {
|
|
|
|
left =base;
|
|
|
|
right=base+num-1;
|
|
|
|
pivot=base[num/2];
|
|
|
|
do {
|
|
|
|
while ((*fp_compare)(*left,pivot)<0)
|
|
|
|
left++;
|
|
|
|
while ((*fp_compare)(*right,pivot)>0)
|
|
|
|
right--;
|
|
|
|
if (left<=right)
|
|
|
|
SwapI64(left++,right--);
|
|
|
|
} while (left<=right);
|
|
|
|
i=right+1-base;
|
|
|
|
if (1<i<num)
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSortI64(base,i,fp_compare);
|
2020-02-15 20:01:48 +00:00
|
|
|
i=base+num-left;
|
|
|
|
if (1<i<num)
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSortI64(left,i,fp_compare);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-02-16 00:35:54 +00:00
|
|
|
U0 QuickSort2a(U8 **base,I64 num,I64 (*fp_compare)(U8 **_e1,U8 **_e2))
|
2020-02-15 20:01:48 +00:00
|
|
|
{//Not public.For case of width==size(U8 *)==8.
|
|
|
|
//fp_compare() passes by ref.
|
|
|
|
I64 i;
|
|
|
|
U8 **left,**right,*pivot;
|
|
|
|
left =base;
|
|
|
|
right=base+num-1;
|
|
|
|
pivot=base[num/2];
|
|
|
|
do {
|
|
|
|
while ((*fp_compare)(left,&pivot)<0)
|
|
|
|
left++;
|
|
|
|
while ((*fp_compare)(right,&pivot)>0)
|
|
|
|
right--;
|
|
|
|
if (left<=right)
|
|
|
|
SwapI64(left++,right--);
|
|
|
|
} while (left<=right);
|
|
|
|
i=right+1-base;
|
|
|
|
if (1<i<num)
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSort2a(base,i,fp_compare);
|
2020-02-15 20:01:48 +00:00
|
|
|
i=base+num-left;
|
|
|
|
if (1<i<num)
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSort2a(left,i,fp_compare);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
2020-02-16 00:35:54 +00:00
|
|
|
U0 QuickSort2b(U8 *base,I64 num, I64 width,
|
2020-02-15 20:01:48 +00:00
|
|
|
I64 (*fp_compare)(U8 *e1,U8 *e2),U8 *tmp)
|
|
|
|
{//Not public
|
|
|
|
I64 i;
|
|
|
|
U8 *left,*right,*pivot=tmp+width;
|
|
|
|
left =base;
|
|
|
|
right=base+(num-1)*width;
|
2020-02-16 03:32:01 +00:00
|
|
|
MemCopy(pivot,base+num/2*width,width);
|
2020-02-15 20:01:48 +00:00
|
|
|
do {
|
|
|
|
while ((*fp_compare)(left,pivot)<0)
|
|
|
|
left+=width;
|
|
|
|
while ((*fp_compare)(right,pivot)>0)
|
|
|
|
right-=width;
|
|
|
|
if (left<=right) {
|
|
|
|
if (left!=right) {
|
2020-02-16 03:32:01 +00:00
|
|
|
MemCopy(tmp,right,width);
|
|
|
|
MemCopy(right,left,width);
|
|
|
|
MemCopy(left,tmp,width);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
|
|
|
left+=width;
|
|
|
|
right-=width;
|
|
|
|
}
|
|
|
|
} while (left<=right);
|
|
|
|
i=1+(right-base)/width;
|
|
|
|
if (1<i<num)
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSort2b(base,i,width,fp_compare,tmp);
|
2020-02-15 20:01:48 +00:00
|
|
|
i=num+(base-left)/width;
|
|
|
|
if (1<i<num)
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSort2b(left,i,width,fp_compare,tmp);
|
2020-02-15 20:01:48 +00:00
|
|
|
}
|
2020-02-16 00:35:54 +00:00
|
|
|
U0 QuickSort(U8 *base,I64 num, I64 width, I64 (*fp_compare)(U8 *e1,U8 *e2))
|
2020-02-15 20:01:48 +00:00
|
|
|
{/*Quick Sort: fp_compare() passes by ref.
|
|
|
|
|
2020-02-16 03:32:01 +00:00
|
|
|
For ascending strings: return StrCompare(*e1,*e2);
|
2020-02-15 20:01:48 +00:00
|
|
|
For ascending ints : return *e1-*e2;
|
|
|
|
Don't return e1-e2 if numbers can overflow, return -1,0 or 1.
|
|
|
|
|
2020-02-16 04:57:03 +00:00
|
|
|
Maybe, look at $LK,"::/Demo/MultiCore/MPRadix.CC"$.
|
2020-02-15 20:01:48 +00:00
|
|
|
*/
|
|
|
|
U8 *tmp;
|
|
|
|
if (width && num>1) {
|
2020-02-16 03:32:01 +00:00
|
|
|
if (width==sizeof(U8 *)) //assign instead of MemCopy for width 8
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSort2a(base,num,fp_compare);
|
2020-02-15 20:01:48 +00:00
|
|
|
else {
|
|
|
|
tmp=MAlloc(width*2);
|
2020-02-16 00:35:54 +00:00
|
|
|
QuickSort2b(base,num,width,fp_compare,tmp);
|
2020-02-15 20:01:48 +00:00
|
|
|
Free(tmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|