qsort和sort函数用法区别

本文对比了sort和qsort函数的使用方式与特点,并详细介绍了如何在不同数据类型和结构体下进行排序操作,包括整型、字符型、浮点型、结构体排序及字符串排序。同时展示了如何自定义比较函数以实现降序排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

区别

sort是qsort的升级版,如果能用sort尽量用sort,使用也比较简单,不像qsort还得自己去写 cmp 函数,

只要注明  使用的库函数就可以使用,参数只有两个(如果是普通用法)头指针和尾指针; 

默认sort排序后是升序,如果想让他降序排列,可以使用自己编的cmp函数

bool compare(int a,int b)

{

  return a>b; //降序排列,如果改为return a<b,则为升序

}

sort(*a,*b,cmp);

sort 使用时得注明:using namespace std;   或直接打 std::sort()  还得加上  #include <algorithm> 

#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
     int a[20];
     for(int i=0;i<20;++i)
         cin>>a[i];
    sort(a,a+20);          //范围,很明显这里是a+20 注意,这是必要的,如果是a+19
    for(i=0;i<20;i++)        //最后一个值a[19]就不会参与排序。
       cout<<a[i]<<endl;
      return 0;
}

std::sort是一个改进版的qsort. std::sort函数优于qsort的一些特点:对大数组采取9项取样,更完全的三路划分算法,更细致的对不同数组大小采用不同方法排序。

qsort   功 能: 使用快速排序例程进行排序   

用 法: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *));   

各参数:1 待排序数组首地址 2 数组中待排序元素数量 3 各元素的占用空间大小 4 指向函数的指针

用于确定排序的顺序 排序方法有很多种, 选择排序,冒泡排序,归并排序,快速排序等。

 看名字都知道快速排序 是目前公认的一种比较好的排序算法(特殊场合例外),比选择排序,冒泡排序都要快。

这是因为他速度很快,所以系统也在库里实现这个算法,便于我们的使用。 这就是qsort。

qsort 要求提供一个 比较函数,是为了做到通用性更好一点。比如你不仅仅的是要排序一个数字而已,可能你要用来排序几个数字 ,

a<本文中排序都是采用的从小到大排序>

一、对int类型数组排序

int num[100];

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

{ return *(int *)a - *(int *)b; }

qsort(num,100,sizeof(num[0]),cmp);

二、对char类型数组排序(同int类型)

char word[100];

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);

六、对字符串进行排序

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);

七、计算几何中求凸包的cmp

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

//重点cmp函数,把除了1点外的所有点,旋转角度排序

{

struct point *c=(point *)a;

struct point *d=(point *)b;

if( calc(*c,*d,p[1]) < 0)

         return 1;

else if( !calc(*c,*d,p[1]) && dis(c->x,c->y,p[1].x,p[1].y) < dis(d->x,d->y,p[1].x,p[1].y))

//如果在一条直线上,则把远的放在前面

        return 1;

else return -1;

}



<think>好的,我现在需要回答用户关于C语言中sort函数qsort函数区别的问题。首先,我要确认用户的问题点在哪里。用户可能已经知道这两个函数都是用于排序的,但想了解它们的具体区别,比如用法、性能、适用场景等。 首先,我需要回忆这两个函数的基本信息。根据提供的引用,qsort是C标准库中的函数,而sort在C语言中可能是指用户自己实现的,或者是C++中的std::sort?不过根据引用[1][2],似乎用户可能混淆了CC++中的函数。比如,C语言本身没有sort函数,而C++的STL中有std::sort。这可能是一个关键点。因此,用户的问题可能需要先澄清,C语言中的sort函数是否存在,或者是否指的是某些特定实现的函数。 根据提供的引用内容,引用[1]提到C语言中的qsortC++中的sort函数。因此,可能用户的问题中的“sort函数”指的是C++中的std::sort,而qsort是C语言的标准库函数。因此,区别主要在于CC++的不同实现。这可能是一个重要的区别点,需要明确告诉用户。 接下来,我需要整理两者的区别。根据引用[1],qsort的比较函数使用函数指针,而sort使用模板或函数对象,提供更灵活的比较规则。引用[2]提到std::sort是改进版的qsort,采用更高效的算法,比如三路划分,对不同大小的数组采用不同方法,性能更好。 另外,类型安全方面,qsort使用void指针,需要用户进行类型转换,容易出错;而C++sort是类型安全的,因为模板会自动推断类型。这也是一个关键区别。 然后,关于性能,qsort因为是通用实现,可能有更多的开销,而sort针对不同数据类型优化,效率更高。引用[2]指出std::sort对大数组使用9项取样,更细致的排序策略,所以更快。 还有,使用方式上,qsort需要显式传递比较函数,参数包括元素大小数量;而sort的参数更简洁,直接传迭代器比较函数(可选)。 需要注意的是,C语言本身没有内置的sort函数,用户可能提到的sort可能是某个库或自己实现的函数,但标准库中只有qsort。而C++中的std::sort属于STL的一部分,所以用户可能在比较C的qsortC++sort。因此,在回答时需要明确这一点,避免混淆。 现在,我需要将这些点组织成一个结构清晰的回答,分点列出区别,并引用提供的资料来支持。同时,用户可能需要示例代码来理解两者的用法差异,比如qsort需要自己写比较函数,而sort可能更简洁。 另外,用户的问题中提到的是C语言中的sortqsort,但根据引用,可能用户将C++sort与C的qsort对比了。因此,在回答时需要指出这一点,避免误解。比如,说明在C语言中标准库只有qsort,而sort属于C++的STL。 最后,生成相关问题,帮助用户进一步学习,比如关于qsort的比较函数实现,或者性能优化的方法等。 总结回答的结构: 1. 明确两个函数所属的语言标准:qsort属于C标准库,sort属于C++ STL。 2. 比较函数的实现方式:函数指针 vs 模板/函数对象。 3. 类型安全性:void指针需要手动转换 vs 自动类型推断。 4. 性能差异:算法优化,如三路划分。 5. 使用示例,代码对比。 6. 应用场景:C项目 vs C++项目。 7. 引用相关文献支持各点。 在回答中,需要确保术语准确,比如qsort的参数(base, num, size, compar),而sort的参数(迭代器,比较函数)。同时,注意用户可能混淆CC++的情况,需明确指出。 现在,我需要检查是否有遗漏的点,比如内存操作、错误处理等方面是否有差异。根据引用[4],qsort的比较函数需要注意解引用类型转换,而sort则不需要,这也是类型安全的一部分。 最后,确保回答符合用户要求的结构:分点清晰,使用中文,正确引用,并生成相关问题。</think>### C语言中sort函数qsort函数区别 在C语言中,标准库仅提供`qsort`函数,而`sort`函数实际上是C++标准模板库(STL)中的一部分。因此,两者的主要区别源于C与C++语言特性及实现方式的不同。以下是具体对比: --- #### 1. **语言标准与归属** - **qsort**:C语言标准库函数,定义在`<stdlib.h>`中[^1][^3]。 - **sort**:C++ STL中的函数,定义在`<algorithm>`中[^1][^2]。 --- #### 2. **比较函数的实现方式** - **qsort**: 需通过**函数指针**传递比较函数函数原型为: ```c int compare(const void* a, const void* b); ``` 用户需自行处理`void*`类型转换,例如: ```c int cmp_int(const void* a, const void* b) { return *(int*)a - *(int*)b; } ``` 使用示例: ```c qsort(arr, n, sizeof(int), cmp_int); ``` [^4] - **sort**: C++中使用**模板****函数对象**(如Lambda表达式)定义比较规则,支持更灵活的语法: ```cpp std::sort(arr.begin(), arr.end(), [](int a, int b) { return a < b; }); ``` 类型自动推断,无需手动转换[^2]。 --- #### 3. **类型安全性** - **qsort**: 基于`void*`指针操作元素,需用户强制类型转换,容易引发错误(如指针解引用错误)[^4]。 - **sort**: 模板机制确保类型安全,编译器自动检查类型匹配,减少运行时错误。 --- #### 4. **性能优化** - **qsort**: 通用排序实现,对任何数据类型采用相同的算法(通常为快速排序),未针对特定数据优化。 - **sort**: 采用混合排序策略(如快速排序+插入排序),对大数组使用**三路划分****9项取样**优化,避免最坏时间复杂度;对小数组直接插入排序。整体效率更高。 --- #### 5. **使用复杂度** - **qsort**: 需手动指定元素数量、元素大小,代码较繁琐: ```c qsort(arr, n, sizeof(element), compare); ``` - **sort**: 通过迭代器操作,参数简洁: ```cpp std::sort(arr.begin(), arr.end()); ``` --- #### 6. **应用场景** - **qsort**: 适用于纯C项目或需兼容C的代码,但对自定义数据类型排序时代码较复杂。 - **sort**: 适用于C++项目,支持泛型编程,尤其适合容器(如`vector`、`array`)复杂对象排序[^2]。 --- ### 总结对比表 | 特性 | qsort (C) | sort (C++) | |--------------|------------------------------------|-------------------------------------| | **类型安全** | 低(需手动类型转换) | 高(自动类型推断) | | **性能** | 一般 | 更优(混合算法优化) | | **语法简洁性** | 复杂(需传递元素大小、数量) | 简单(迭代器直接操作) | | **扩展性** | 依赖函数指针 | 支持Lambda、函数对象 | ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值