• 总结一下qsort()函数的使用与注意


     
    一、简介
     
    原 型: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));
    功 能: 使用快速排序例程进行排序
     
    参 数:1 待排序数组首地址 2 数组中待排序元素数量 3 各元素的占用空间大小 4 指向函数的指针,用于确定排序的顺序
    说 明:qsort函数是ANSI C标准中提供的,其声明在stdlib.h文件中,是根据二分法写的,其时间复杂度为n*log(n)。
         qsort要求提供的函数是需要自己定义的一个比较函数,比较函数使得qsort通用性更好。有了比较函数qsort可以实现对数组、字符串、结构体等结构进行升序或降序排序。
         如int cmp(const void *a, const void *b)中有两个元素作为参数,返回一个int值,如果比较函数返回大于0,qsort就认为a > b,返回小于0qsort就认为a < b。qsort知道元素的大小了,就可以把大的放前面去。如果你的比较函数返回本来应该是1的(即a > b),而却返回-1(小于0的数),那么qsort认为a < b,就把b放在前面去,但实际上是a > b的,所以就造成了降序排序的差别了。
         简单来说,比较函数的作用就是给qsort指明元素的大小事怎么比较的。
     
    二、使用举例(MinGW5测试通过)
     
    1、对一维数组排序:
       
     
    2、对字符串排序:
     
    #include <stdio.h>
    #include <stdlib.h>
    
    typedef char Element_type;
    
    Element_type list[] = "djfkwjefklwefagj"; 
    
    int Comp(const void *p1,const void *p2)
    {
    	//降序排序
    	return strcmp((char *)p2,(char *)p1);
    	//升序排序
    	//return strcmp((char *)p1,(char *)p2);
    }
    
    int main(void)
    {
    	puts("排序前:");
    	puts(list);
    	printf("\n");
    	
    	//考虑还有字符串结束符,这里元素个数别忘减1
    	qsort(list, sizeof(list) / sizeof(Element_type) - 1, sizeof(Element_type), Comp);
    	system("pause");
    	
    	puts("排序后:");
    	puts(list);
    	printf("\n");
    	
    
    	return 0;
    }
    

    3、按结构体中某个关键字排序(对结构体一级排序):
    #include <stdio.h>
    #include <stdlib.h>
    
    struct Node
    {
    	double data;
    	int other;
    }s[100];
    
    int Comp(const void *p1,const void *p2)
    {
    	return (*(Node *)p2)->data - (*(Node *)p1)->data;
    }
    
    int main(void)
    {
    	puts("排序前:");
    	//code
    	printf("\n");
    	
    	qsort(s, 100, sizeof(s[0]), Comp);
    	system("pause");
    	
    	puts("排序后:");
    	//code
    	printf("\n");
    
    	return 0;
    }
    
    4、按结构体中多个关键字排序(对结构体多级排序)[以二级为例]:
    struct Node
    {
       int x;
       int y;
    }s[100];//按照x从小到大排序,当x相等时按y从大到小排序
    int Comp(const void *p1,const void *p2)
    {
       struct Node *c = (Node *)p1;
       struct Node *d = (Node *)p2;
     
      if(c->x != d->x) return c->x - d->x;
       else return d->y - c->y;
    }
    
    5、对结构体中字符串进行排序:
    struct Node
    {
    	int data;
    	char str[100];
    }s[100];
    
    //按照结构体中字符串 str 的字典序排序
    int Comp(const void *p1,const void *p2)
    {
    	return strcmp((*(Node *)p1)->str,(*(Node *)p2)->str);
    }
    
    
  • 相关阅读:
    剖析C语言中a=a+++++a的无聊问题
    [转]精确到1%秒的单片机计时器汇编程序
    [转]学DSP、FPGA、ARM,哪个更有前途?
    【Java】Eclipse导出JAR包
    二维码生成器(支持历史记录点击和清空)
    移动端开发注意之一二
    localStorage实现按钮点击禁用
    JavaScript之查找元素
    扒拉扒拉table
    解惑之JavaScript
  • 原文地址:https://www.cnblogs.com/pang123hui/p/1947003.html
Copyright © 2020-2023  润新知