qsort.c
上传用户:wstnjxml
上传日期:2014-04-03
资源大小:7248k
文件大小:2k
源码类别:

Windows CE

开发平台:

C/C++

  1. /*****************************************************************************
  2.  *
  3.  * This program is free software ; you can redistribute it and/or modify
  4.  * it under the terms of the GNU General Public License as published by
  5.  * the Free Software Foundation; either version 2 of the License, or
  6.  * (at your option) any later version.
  7.  *
  8.  * This program is distributed in the hope that it will be useful,
  9.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11.  * GNU General Public License for more details.
  12.  *
  13.  * You should have received a copy of the GNU General Public License
  14.  * along with this program; if not, write to the Free Software
  15.  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
  16.  *
  17.  * $Id: qsort.c 271 2005-08-09 08:31:35Z picard $
  18.  *
  19.  * The Core Pocket Media Player
  20.  * Copyright (c) 2004-2005 Gabor Kovacs
  21.  *
  22.  ****************************************************************************/
  23. #include <stdio.h>
  24. #include <stdlib.h>
  25. #include <string.h>
  26. // cheap fake bubble sort :)))
  27. #if defined(__GNUC__)
  28. #define alloca(size) __builtin_alloca(size)
  29. #else
  30. #include <malloc.h>
  31. #endif
  32. void qsort(void *const base, size_t num, size_t size,int (*cmp)(const void*, const void*))
  33. {
  34. if (num>1)
  35. {
  36. void* tmp = alloca(size);
  37. int changed;
  38. do
  39. {
  40. char* p  = (char*)base;
  41. char* pe = p + num*size;
  42. changed = 0;
  43. for (p+=size;p!=pe;p+=size)
  44. if (cmp(p-size,p)>0)
  45. {
  46. memcpy(tmp,p,size);
  47. memcpy(p,p-size,size);
  48. memcpy(p-size,tmp,size);
  49. changed = 1;
  50. }
  51. }
  52. while (changed);
  53. }
  54. }