⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 testsort.cpp

📁 快速排序源代码
💻 CPP
字号:
// testsort.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"
#include <string.h>

#define CUTOFF 8

static void shortsort(char *lo, char *hi, unsigned width, int (*comp)(const void *, const void *));
static void swap(char *p, char *q, unsigned int width);

void qsort(void *base, unsigned num, unsigned width, int (*comp)(const void *, const void *))
{
  char *lo, *hi;
  char *mid;
  char *loguy, *higuy;
  unsigned size;
  char *lostk[30], *histk[30];
  int stkptr;

  if (num < 2 || width == 0) return;
  stkptr = 0;

  lo = (char*)base;
  hi = (char *) base + width * (num - 1);

recurse:
  size = (hi - lo) / width + 1;

  if (size <= CUTOFF) 
  {
    shortsort(lo, hi, width, comp);
  }
  else 
  {
    mid = lo + (size / 2) * width;
    swap(mid, lo, width);

    loguy = lo;
    higuy = hi + width;

    for (;;) 
    {
      do { loguy += width; } while (loguy <= hi && comp(loguy, lo) <= 0);
      do { higuy -= width; } while (higuy > lo && comp(higuy, lo) >= 0);
      if (higuy < loguy) break;
      swap(loguy, higuy, width);
    }

    swap(lo, higuy, width);

    if (higuy - 1 - lo >= hi - loguy) 
    {
      if (lo + width < higuy) 
      {
        lostk[stkptr] = lo;
        histk[stkptr] = higuy - width;
        ++stkptr;
      }

      if (loguy < hi) 
      {
        lo = loguy;
        goto recurse;
      }
    }
    else
    {
      if (loguy < hi) 
      {
        lostk[stkptr] = loguy;
        histk[stkptr] = hi;
        ++stkptr;
      }

      if (lo + width < higuy) 
      {
        hi = higuy - width;
        goto recurse;
      }
    }
  }

  --stkptr;
  if (stkptr >= 0) 
  {
    lo = lostk[stkptr];
    hi = histk[stkptr];
    goto recurse;
  }
  else
    return;
}

static void shortsort(char *lo, char *hi, unsigned width, int (*comp)(const void *, const void *))
{
  char *p, *max;

  while (hi > lo) 
  {
    max = lo;
    for (p = lo+width; p <= hi; p += width) if (comp(p, max) > 0) max = p;
    swap(max, hi, width);
    hi -= width;
  }
}

static void swap(char *a, char *b, unsigned width)
{
  char tmp;

  if (a != b)
  {
    while (width--) 
    {
      tmp = *a;
      *a++ = *b;
      *b++ = tmp;
    }
  }
}

/*
int CompStr(const void* str1, const void* str2)
{
	return stricmp((char*)str1, (char*)str2);
}

char StrList[3][4] = {"dbc","bbc","abc"};

int main(int argc, char* argv[])
{
	qsort(StrList, 3, 4, CompStr);

	printf("Hello World!\n");
	return 0;
}
*/
/*
int CompNum(const void* n1, const void* n2)
{
	int nN1 = *((int*)n1);
	int nN2 = *((int*)n2);
	
	return nN1 - nN2;
}

int IntList[3] = {8, 5, 6};

int main(int argc, char* argv[])
{
	qsort(IntList, 3, 4, CompNum);

	printf("Hello World!\n");
	return 0;
}
*/


int CompStr(const void* str1, const void* str2)
{
	//return stricmp((char*)str1[0], (char*)str2);

	char **pStr1 = (char**)(str1);
	char **pStr2 = (char**)(str2);
	if (*pStr1 == NULL)
		return 1;
	else if (*pStr2 == NULL)
		return -1;
	return stricmp(*pStr1, *pStr2);
}

char *StrList[4];
char *s1 = "dbc";
char *s2 = "abc";
char *s3 = NULL;
char *s4 = "fbc";

unsigned int nLsl = 0x7908;

int main(int argc, char* argv[])
{
	StrList[0] = s1;
	StrList[1] = s2;
	StrList[2] = s4;
	StrList[3] = s3;
	qsort(StrList, 4, 4, CompStr);

	nLsl = nLsl << 27;

	printf("Hello World!\n");
	return 0;
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -