sort.c 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. #include "global.h"
  2. #include "sort.h"
  3. /* -------------------------------------------------------------------------
  4. NAME: SortZBuffer
  5. AUTHOR: Unknown (original Commodore 64 basic program)
  6. C version in 1992 by Terence Russell.
  7. PURPOSE: Sorts an array structure which is defined with an index range of
  8. 0 to (maxElement-1).
  9. The sort is a Metzner Shell sort. I've done several tests on an
  10. Amiga 500 & 3000 with various sorts of data and have found this
  11. routine is just as fast as the QuickSort algorithm. As well it
  12. doesn't have the problem QuickSort has with sorting data which
  13. is nearly sorted to begin with.
  14. NOTE: No Copyright is claimed on this routine.
  15. ------------------------------------------------------------------------- */
  16. void SORTWORLD(zBufferType *BUFFER, word maxElement)
  17. {
  18. register word ShellSize = maxElement, loop, index, index2, preCalc;
  19. register word SWAP;
  20. while(ShellSize = ShellSize >> 1) /* >> 1 is equivalent to / 2 but faster*/
  21. {
  22. preCalc = maxElement - ShellSize; /* Faster assembly code! */
  23. for(loop = 0; loop < preCalc; loop++)
  24. {
  25. index = loop;
  26. for(;;)
  27. {
  28. index2 = index + ShellSize;
  29. /* Change > to < for descending values. */
  30. if( BUFFER[index][1] > BUFFER[index2][1]) /* element [x][1] is the comparison element*/
  31. {
  32. SWAP = BUFFER[index2][0];
  33. BUFFER[index2][0] = BUFFER[index][0]; /* move element 0 */
  34. BUFFER[index][0] = SWAP;
  35. SWAP = BUFFER[index2][1];
  36. BUFFER[index2][1] = BUFFER[index][1]; /* move element 1 */
  37. BUFFER[index][1] = SWAP;
  38. index = index - ShellSize;
  39. if(index < 0) break;
  40. }
  41. else break;
  42. }
  43. }
  44. }
  45. }