C语言中 stdlib.h中的qsort排序用法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了C语言中 stdlib.h中的qsort排序用法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1795字,纯文字阅读大概需要3分钟。
内容图文
![C语言中 stdlib.h中的qsort排序用法](/upload/InfoBanner/zyjiaocheng/1325/8a5a38937cd94a22a0f7c8a36e693c19.jpg)
今天在刷leetcode的时候,发现快排居然C语言也有写好的库函数直接调用。真神奇。
一共有其中排序qsort的排序用法。
需要注意的是排序都是采用的从小到大的排序。
一、对int类型数组排序
int num[100];
int cmp ( const void *a , const void *b )
{
return *(int *)a - *(int *)b;
}
qsort(num,100,sizeof(num[0]),cmp);
二、对char类型数组排序(同int类型)
char word[50];
Sample:
int cmp( const void *a , const void *b )
{
return *(char *)a - *(int *)b;
}
qsort(word,100,sizeof(word[0]),cmp);
三、对double类型数组排序
double in[100];
int cmp( const void *a , const void *b )
{
return *(double *)a > *(double *)b ? 1 : -1;
}
qsort(in,100,sizeof(in[0]),cmp);
四、对结构体一级排序
struct In
{
double data;
int other;
}s[100]
//按照data的值从小到大将结构体排序,关于结构体内的排序关键数据data的类型可以很多种,参考上面的例子写
int cmp( const void *a ,const void *b)
{
return (*(In *)a).data > (*(In *)b).data ? 1 : -1;
}
qsort(s,100,sizeof(s[0]),cmp);
五、对结构体二级排序
struct In
{
int x;
int y;
}s[100];
//按照x从小到大排序,当x相等时按照y从大到小排序
int cmp( const void *a , const void *b )
{
struct In *c = (In *)a;
struct In *d = (In *)b;
if(c->x != d->x) return c->x - d->x;
else return d->y - c->y;
}
qsort(s,100,sizeof(s[0]),cmp);
六、对结构体三级排序(都是从小到大)
#include<stdlib.h>
typedef struct item
{
int num,length,width;
};
int comp(const void *p1,const void *p2)
{
struct item *c=(item*)p1;
struct item *d=(item*)p2;
if(c->num!=d->num)
{
return d->num<c->num?1:-1;
}
else if(c->length!=d->length&&c->num==d->num)
return d->length<c->length?1:-1;
else return d->width<c->width?1:-1;
}
item ss[1200];
qsort(ss,n,sizeof(ss[0]),comp);
七、对字符串进行排序
struct In
{
int data;
char str[100];
}s[100];
//按照结构体中字符串str的字典顺序排序
int cmp ( const void *a , const void *b )
{
return strcmp( (*(In *)a)->str , (*(In *)b)->str );
}
qsort(s,100,sizeof(s[0]),cmp);
原文:https://www.cnblogs.com/Alei777/p/13223633.html
内容总结
以上是互联网集市为您收集整理的C语言中 stdlib.h中的qsort排序用法全部内容,希望文章能够帮你解决C语言中 stdlib.h中的qsort排序用法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。