1.首先了解

int cmp(const void* a, const void* b)

表示声明cmp函数,其返回值为int型,参数为两个不可修改(const)的void型指针

2.函数原型

函数声明

void qsort(void *base, number, size, int (*cmp)(const void *p1, const void*p1))

参数

  • base-- 指向要排序的数组的第一个元素的指针。//一般填写数组名
  • number-- 由 base 指向的数组中元素的个数。
  • size-- 数组中每个元素的大小,以字节为单位。
  • cmp-- 用来比较两个元素的函数.
     int compar(const void *p1, const void *p2)
            {return *(int*)p2-*(int*)p2;}//这个是由小到大排序,return *(int *)p2 - *(int *)p1; 为由大到小排序。
       如果cmp返回值小于0(< 0),那么p1所指向元素会被排在p2所指向元素的左边;
  如果cmp返回值等于0(= 0),那么p1所指向元素与p2所指向元素的顺序不确定;
  如果cmp返回值大于0(> 0),那么p1所指向元素会被排在p2所指向元素的右边。
 
3.调用该函数需要声明  #include<stdlib.h>
4.对二维数组进行排序,本质是对每行的首地址元素进行排序

#include<stdio.h>
#include<stdlib.h>
int comp(const void*a,const void*b)
{
return ((int*)a)[]-((int*)b)[];
}
int main()
{
int i,j;
int a[][];
int n;
scanf("%d",&n);//假设n=3 for(i=;i<n;i++)
for(j=;j<;j++)
scanf("%d",&a[i][j]);//假设输人4,2,1,3,5,6
//实际是对4,1,5进行排序
qsort(a,n,sizeof(int)*,comp);
for(i=;i<n;i++)
for(j=;j<;j++)
printf("%d \n",a[i][j]);//输出1,3,4,2,5,6
return ;
}

5.对结构体中的某个元素排序

#include<stdio.h>
#include<stdlib.h>
struct In
{
int data;
int other;
}s[];
int cmp( const void *a ,const void *b) {
// return (*(In *)a).data > (*(In *)b).data ? 1 : -1;
//转自大佬..
//注意,这条语句在VC6.0环境下运行可能会出错,但是并不是语句错了,而是你要先 Build ,或者全部重建。总之语句是对的。
// 或者你可以将这上面1条语句改成下面这3条语句 struct In *aa = (In *)a;
struct In *bb = (In *)b;
return aa->data > bb->data ? : -;//data可以换成结构体中的其他项
} int main()
{
int n,i;
scanf("%d",&n);
for(i=;i<n;i++)
scanf("%d%d",&s[i].data,&s[i].other);
qsort(s,n,sizeof(s[]),cmp);
for(i=;i<n;i++)
printf("%d\n",s[i].data); return ;
}

c语言中的qsort用法的更多相关文章

  1. C语言中sizeof()的用法

    语法 sizeof有三种语法形式: 1.sizeof(object); //sizeof(对象); 2.sizeof(type_name); //sizeof(类型); 3.sizeof object ...

  2. C/C++语言中const的用法

    1. const 在C和C++中的区别     C++中的const正常情况下是看成编译期的常量,编译器并不为const分配空间,只是在编译的时候将期值保存在名字表中,并在适当的时候折合在代码中. 所 ...

  3. 在不同语言中static的用法

    static (计算机高级语言) 编辑 像在VB,C#,C,C++,Java,PHP中我们可以看到static作为关键字和函数出现,在其他的高级计算机语言如FORTRAN.ALGOL.COBOL.BA ...

  4. C语言中 malloc函数用法

    一.malloc()和free()的基本概念以及基本用法: 1.函数原型及说明: void *malloc(long NumBytes):该函数分配了NumBytes个字节,并返回了指向这块内存的指针 ...

  5. 浅析C语言中assert的用法(转)

    原文地址:http://www.jb51.net/article/39685.htm 以下是对C语言中assert的使用方法进行了介绍,需要的朋友可以参考下. assert宏的原型定义在<ass ...

  6. C语言中extern的用法--转

    http://blog.sina.com.cn/s/blog_52deb9d50100ml6y.html 在C语言中,修饰符extern用在变量或者函数的声明前,用来说明“此变量/函数是在别处定义的, ...

  7. C语言中#define的用法(转)

    转自:http://www.dingge.com/main/article.asp?id=10 今天整理了一些#define的用法,与大家共享! 1.简单的define定义 #define MAXTI ...

  8. C语言中#define的用法

    今天整理了一些#define的用法,与大家共享! 1.简单的define定义 #define MAXTIME 1000 一个简单的MAXTIME就定义好了,它代表1000,如果在程序里面写 if(i& ...

  9. C语言中 sscanf 的用法

    名称: sscanf() - 从一个字符串中读进与指定格式相符的数据. 函数原型: Int sscanf( string str, string fmt, mixed var1, mixed var2 ...

随机推荐

  1. (转)多进程 & 多线程的区别与适用场景

    转自:http://www.cnblogs.com/huntfor/p/4021327.html 关于多进程和多线程,教科书上最经典的一句话是“进程是资源分配的最小单位,线程是CPU调度的最小单位”, ...

  2. 后端分页神器,mybatis pagehelper 在SSM与springboot项目中的使用

    mybatis pagehelper想必大家都耳熟能详了,是java后端用于做分页查询时一款非常好用的分页插件,同时也被人们称为mybatis三剑客之一,下面 就给大家讲讲如何在SSM项目和sprin ...

  3. 如何预测股票分析--自动ARIMA

    在上一篇中,我们发现knn和线性回归一样,表现的不是特别好,来看看时间序列的表现 时间序列预测法其实是一种回归预测方法,属于定量预测,其基本原理是;一方面承认事物发展的延续性,运用过去时间序列的数据进 ...

  4. echarts相关问题记录

    1.图标距离容器边界 //echats options options : { //... grid : { top : 40, //距离容器上边界40像素 bottom: 30 //距离容器下边界3 ...

  5. RestTemplate-记录

    org.springframework.web.client.RestTemplate 1.从使用功能上看,是一种简化请求响应的工具类,从发送请求,到对返回的结果进行json解析.格式不对会有异常.

  6. 【想见你】剧情解析byZlc

    花两天时间刷完了想见你,精神有点恍惚. 要是刷题也能有这个尽头就好了... 下面给大家带来个人的剧(hu)情(bian)解(luan)析(zao) 穿越条件:一台老式随身听,一首last dance, ...

  7. python中给函数传参是传值还是传引用

    首先还是应该科普下函数参数传递机制,传值和传引用是什么意思? 函数参数传递机制问题在本质上是调用函数(过程)和被调用函数(过程)在调用发生时进行通信的方法问题.基本的参数传递机制有两种:值传递和引用传 ...

  8. float和position:absolute脱离文本流的区别

    float和position:absolute脱离文本流的区别原创 paediatrician 最后发布于2016-09-19 10:43:05 阅读数 5375 收藏展开 文档流:将窗体自上而下分成 ...

  9. mybatis--MyBatis动态SQL语句

    mybatis 的动态sql语句是基于OGNL表达式的.可以方便的在 sql 语句中实现某些逻辑. 总体说来mybatis 动态SQL 语句主要有以下几类: 1. if 语句 (简单的条件判断) 2. ...

  10. Mysql实现级联操作(级联更新、级联删除)(转)

    一.首先创建两张表stu,sc create table stu( sid int UNSIGNED primary key auto_increment, name varchar(20) not ...