qsort与sort函数区别点

本文详细介绍了C语言标准库函数qsort与C++标准模板库中的sort函数的区别及使用方法,包括不同数据类型的排序示例,并对比了两者之间的优缺点。

转载自http://blog.youkuaiyun.com/yzl_rex/article/details/7874513

下面先对qsort和sort进行详细的解释,然后再将区别!(需要特别注意的就是qsort和sort的比较函数的写法,很容易出错)


First qsort
基本快速排序的方法,每次把数组分成两分和中间的一个划分值,而对于有多个重复值的数组来说,基本排序的效率较低。集成在C语言库函数里面的的qsort函数,使用三路划分的方法解决这个问题。所谓三路划分,是指把数组划分成小于划分值,等于划分值和大于划分值的三个部分。
函数对buf 指向的数据按升序排序。


使用方法:
void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )
int compare (const void *elem1, const void *elem2 ) );
qsort(quicksort)主要根据你给的比较条件给一个快速排序,主要是通过指针移动实现排序功能。排序之后的结果仍然放在原来数组中。
参数意义如下:
base:需要排序的目标数组开始地址
num:目标数组元素个数
width:目标数组中每一个元素长度
compare:函数指针,指向比较函数

一、对int类型数组排序
int num[100];
int cmp ( const void *a , const void *b )
{
return *(int *)a - *(int *)b;
}
可见:参数列表是两个空指针,现在他要去指向你的数组元素。所以转型为你当前的类型,然后取值。升序排列。
因为是按照acs码的值进行的,所以在前面的字符的值一定小于后面的字符。
那么,对于a b,如果a的值>b的值,就说明在字母表中a在b的后面,返回值为1表示ture,执行交换。


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

二、对char类型数组排序(同int类型)
char word[100];
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;
返回值的问题,显然cmp返回的是一个整型,所以避免double返回小数而被丢失。
}
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);
六、对字符串进行排序
char str[100][100];
int cmp(const void* a,const void* b )
{
return strcmp((char *)a,(char*)b);
}
qsort(str,n,sizeof(str[0]),cmp);
值得注意的是,上面的n,很有可能你会误认为是100,这里实际应该是你要排序的个数,比如说你实际上只有str[0],str[1],str[2]这三个字符串要排序,那么n就应该是3,而不是100;

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);
注意!qsort 中的 cmp 得自己写 。







Second sort
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项取样,更完全的三路划分算法,更细致的对不同数组大小采用不同方法排序。






Third 区别:
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和qsort的比较函数的主要区别:
例如要对一个数组进行排序:

#include <iostream>
#include <algorithm>
using namespace std;

//下面的比较函数的返回值为0或者1 
bool cmp1(int m, int n)
{
     return m > n;
}

bool cmp3(int m, int n)
{
     return m - n;
}
 
 
int cmp2(const void *a, const void *b)
{
    return *(int *)a - *(int *)b;
}


int main()
{
    int a[10] = {8, 6, 9, 4, 21, 1, 1, 3, 78, -5};
    sort(a, a+10, cmp1);
    //sort(a, a+10, cmp3);
    //qsort(a, 10, sizeof(int), cmp2);
    for (int i = 0; i < 10; i++)
        cout << a[i] << " ";
    cout << endl;
    
    system("pause");
}


可以看出上面的结果是出乎意料的!为什么sort中的比较函数改为这样就会出错呢?!
是因为:在cmp1的比较函数中,其返回值为0和1,而在cmp2的比较函数中,其返回值为0,-1和1!

再看看下面的例子:
#include <iostream>
using namespace std;

bool solve(int a, int b)
{
    //return a - b; 
    return a > b; 
} 

int main()
{
    int a = 5, b = 10;
    if (solve(a, b))//这个当小于0的时候,也是返回真!
        cout << a << endl;
    else 
        cout << b << endl; 
    
    system("pause"); 
} 


 

Java是一种具备卓越性能广泛平台适应性的高级程序设计语言,最初由Sun Microsystems(现属Oracle公司)的James Gosling及其团队于1995年正式发布。该语言在设计上追求简洁性、稳定性、可移植性以及并发处理能力,同时具备动态执行特性。其核心特征显著优可归纳如下: **平台无关性**:遵循“一次编写,随处运行”的理念,Java编写的程序能够在多种操作系统硬件环境中执行,无需针对不同平台进行修改。这一特性主要依赖于Java虚拟机(JVM)的实现,JVM作为程序底层系统之间的中间层,负责解释并执行编译后的字节码。 **面向对象范式**:Java全面贯彻面向对象的设计原则,提供对封装、继承、多态等机制的完整支持。这种设计方式有助于构建结构清晰、模块独立的代码,提升软件的可维护性扩展性。 **并发编程支持**:语言层面集成了多线程处理能力,允许开发者构建能够同时执行多项任务的应用程序。这一特性尤其适用于需要高并发处理的场景,例如服务器端软件、网络服务及大规模分布式系统。 **自动内存管理**:通过内置的垃圾回收机制,Java运行时环境能够自动识别并释放不再使用的对象所占用的内存空间。这不仅降低了开发者在内存管理方面的工作负担,也有效减少了因手动管理内存可能引发的内存泄漏问题。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
<think>好的,我现在需要回答用户关于C语言中sort函数qsort函数区别的问题。首先,我要确认用户的问题在哪里。用户可能已经知道这两个函数都是用于排序的,但想了解它们的具体区别,比如用法、性能、适用场景等。 首先,我需要回忆这两个函数的基本信息。根据提供的引用,qsort是C标准库中的函数,而sort在C语言中可能是指用户自己实现的,或者是C++中的std::sort?不过根据引用[1]和[2],似乎用户可能混淆了C和C++中的函数。比如,C语言本身没有sort函数,而C++的STL中有std::sort。这可能是一个关键。因此,用户的问题可能需要先澄清,C语言中的sort函数是否存在,或者是否指的是某些特定实现的函数。 根据提供的引用内容,引用[1]提到C语言中的qsort和C++中的sort函数。因此,可能用户的问题中的“sort函数”指的是C++中的std::sort,而qsort是C语言的标准库函数。因此,区别主要在于C和C++的不同实现。这可能是一个重要的区别,需要明确告诉用户。 接下来,我需要整理两者的区别。根据引用[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的qsort和C++的sort。因此,在回答时需要明确这一,避免混淆。 现在,我需要将这些组织成一个结构清晰的回答,分列出区别,并引用提供的资料来支持。同时,用户可能需要示例代码来理解两者的用法差异,比如qsort需要自己写比较函数,而sort可能更简洁。 另外,用户的问题中提到的是C语言中的sortqsort,但根据引用,可能用户将C++的sortC的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的参数(迭代器,比较函数)。同时,注意用户可能混淆C和C++的情况,需明确指出。 现在,我需要检查是否有遗漏的,比如内存操作、错误处理等方面是否有差异。根据引用[4],qsort的比较函数需要注意解引用和类型转换,而sort则不需要,这也是类型安全的一部分。 最后,确保回答符合用户要求的结构:分清晰,使用中文,正确引用,并生成相关问题。</think>### C语言中sort函数qsort函数区别 在C语言中,标准库仅提供`qsort`函数,而`sort`函数实际上是C++标准模板库(STL)中的一部分。因此,两者的主要区别源于CC++语言特性及实现方式的不同。以下是具体对比: --- #### 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、函数对象 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值