欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言qsort()函數(shù)的使用方法詳解

 更新時(shí)間:2022年06月02日 08:58:38   作者:ZDDWLIG  
qsort是一個(gè)庫函數(shù),基于快速排序算法實(shí)現(xiàn)的一個(gè)排序的函數(shù),下面這篇文章主要給大家介紹了關(guān)于C語言qsort()函數(shù)使用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

 qsort()函數(shù)(quick sort)是八大排序算法中的快速排序,能夠排序任意數(shù)據(jù)類型的數(shù)組其中包括整形,浮點(diǎn)型,字符串甚至還有自定義的結(jié)構(gòu)體類型。

1.參數(shù)含義

void qsort (void* base, size_t num, size_t size,int (*compar)(const void*,const void*));

 上圖是qsort函數(shù)各個(gè)參數(shù)的含義,讓我們一個(gè)個(gè)來看。

1.首元素地址base

我們要排序一組數(shù)據(jù),首先我們需要找到這組數(shù)據(jù)在哪,因此我們直接將首元素的地址傳給qsort函數(shù)來確定從哪開始排序。

2.元素個(gè)數(shù)num

我們知道了從哪開始,也要知道在哪結(jié)束才能確定一組需要排序的數(shù)據(jù),但是我們不方便直接將結(jié)尾元素的地址傳入函數(shù),因此我們將需要排序的元素的個(gè)數(shù)傳給qsort函數(shù)來確定一組數(shù)據(jù)。

3.元素大小size

我們知道qsort函數(shù)能排序任意數(shù)據(jù)類型的一組數(shù)據(jù),因此我們用void*類型的指針來接收元素,但是我們知道void*類型的指針不能進(jìn)行加減操作,也就無法移動(dòng),那么在函數(shù)內(nèi)部我們究竟用什么類型的指針來操作變量呢?我們可以將void*類型的指針強(qiáng)制類型轉(zhuǎn)換成char*類型的指針后來操作元素,因?yàn)閏har*類型的指針移動(dòng)的單位字節(jié)長度是1個(gè)字節(jié),我們只需要再知道我們需要操作的數(shù)據(jù)是幾個(gè)字節(jié)就可以操作指針從一個(gè)元素移動(dòng)到下一個(gè)元素,因此我們需要將元素大小傳入qsort函數(shù)。

4.自定義比較函數(shù)compar

我們需要告訴qsort函數(shù)我們希望數(shù)據(jù)按照怎么的方式進(jìn)行比較,比如對(duì)于幾個(gè)字符串,我們可以比較字符串的大?。╯trcmp),也可以比較字符串的長度(strlen),因此我們要告訴qsort函數(shù)我們希望的比較方式,我們就需要傳入一個(gè)比較函數(shù)compar就簡寫為cmp吧。

2.使用方式

1.頭文件

 要使用qsort函數(shù)我們首先需要引用一個(gè)頭文件<stdlib,h>

#include <stdlib.h>

2.compar的實(shí)現(xiàn)

qsort函數(shù)給cmp函數(shù)規(guī)定了特定的參數(shù)。因此我們?cè)O(shè)計(jì)cmp函數(shù)時(shí)要嚴(yán)格遵守其參數(shù)設(shè)定。

int compar (const void* e1, const void* e2);

如果你要比較的數(shù)據(jù)是整形:

int cmp_int(const void* e1, const void* e2)
{
	return *(int*)e1 - *(int*)e2;
}

如果你要比較的數(shù)據(jù)是浮點(diǎn)型:

int cmp_float(const void* e1, const void* e2)
{
	return (int)(*(float*)e1 - *(float*)e2);
}

如果你要比較的是字符串的大小:

int cmp_str_len(const void* e1, const void* e2)
{
	return strlen((char*)e1)-strlen((char*)e2);
}

如果你要比較的是字符串的長度:

int cmp_str_len(const void* e1, const void* e2)
{
	return strlen((char*)e1)-strlen((char*)e2);
}

如果你要比較的數(shù)據(jù)是結(jié)構(gòu)體變量:

int cmp_by_age(const void*e1, const void*e2)
{
	return (int)(((stu*)e1)->weight - ((stu*)e2)->weight);
}

 需要注意的是:返回結(jié)果一定要確保是整形,如果不是一定要強(qiáng)制類型轉(zhuǎn)換成整形!

3.整體代碼

快速排序結(jié)構(gòu)體變量示例:

#include <stdlib.h>
typedef struct stu
{
	//char name;
	int age;
	float weight;
	double hight;
}stu;
int cmp_by_age(const void*e1, const void*e2)
{
	return (int)(((stu*)e1)->weight - ((stu*)e2)->weight);
}
int main()
{
	stu class1[3] = { {17,185.5,190.8}, {16,160.9,200.7}, {18,120.3,150.5} };
	int sz = sizeof(class1) / sizeof(class1[0]);
	int i;
	qsort(class1, sz,sizeof(class1[0]), cmp_by_age);
	for (i = 0; i < 3; i++)
	{
		printf("%.1f\n", class1[i].weight);
	}
	return 0;
}

總結(jié)

到此這篇關(guān)于C語言qsort()函數(shù)使用的文章就介紹到這了,更多相關(guān)C語言qsort()函數(shù)使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言代碼實(shí)現(xiàn)2048游戲

    C語言代碼實(shí)現(xiàn)2048游戲

    這篇文章主要為大家詳細(xì)介紹了C語言代碼實(shí)現(xiàn)2048游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • C++強(qiáng)制類型轉(zhuǎn)換(static_cast、dynamic_cast、const_cast、reinterpret_cast)

    C++強(qiáng)制類型轉(zhuǎn)換(static_cast、dynamic_cast、const_cast、reinterpret_ca

    本文主要介紹了C++強(qiáng)制類型轉(zhuǎn)換,主要介紹了static_cast、dynamic_cast、const_cast、reinterpret_cast的4種方法,感興趣的可以了解一下
    2021-08-08
  • 詳解Qt使用QImage類實(shí)現(xiàn)圖像基本操作

    詳解Qt使用QImage類實(shí)現(xiàn)圖像基本操作

    這篇文章主要介紹了Qt如何利用QImage類實(shí)現(xiàn)對(duì)圖像的基本操作,包括圖像顯示、圖像縮放、圖像旋轉(zhuǎn)等,感興趣的小伙伴可以跟隨小編一起動(dòng)手嘗試一下
    2022-06-06
  • 如何用C++實(shí)現(xiàn)A*尋路算法

    如何用C++實(shí)現(xiàn)A*尋路算法

    尋路是游戲比較重要的一個(gè)組成部分。因?yàn)椴粌HAI還有很多地方(例如RTS游戲里操控人物點(diǎn)到地圖某個(gè)點(diǎn),然后人物自動(dòng)尋路走過去)都需要用到自動(dòng)尋路的功能。本文將介紹一個(gè)經(jīng)常被使用且效率理想的尋路方法-A*尋路算法,并且提供額外的優(yōu)化思路
    2021-06-06
  • 用typedef定義類型的總結(jié)分析

    用typedef定義類型的總結(jié)分析

    除了可以直接使用C提供的標(biāo)準(zhǔn)類型名(如:int ,char ,float,double,long等)和自己聲明的結(jié)構(gòu)體、共用體、枚舉類型外,還可以使用typedef聲明 新的類型名 來代替 已有的 類型名
    2013-08-08
  • C++中的模板類&模板函數(shù)

    C++中的模板類&模板函數(shù)

    這篇文章主要介紹了C++中的模板類&模板函數(shù)用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++中string使用+號(hào)與int拼接方式

    C++中string使用+號(hào)與int拼接方式

    這篇文章主要介紹了C++中string使用+號(hào)與int拼接方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • C語言中的結(jié)構(gòu)體的入門學(xué)習(xí)教程

    C語言中的結(jié)構(gòu)體的入門學(xué)習(xí)教程

    這篇文章主要介紹了C語言中的結(jié)構(gòu)體的入門學(xué)習(xí)教程,以struct語句定義的結(jié)構(gòu)體是C語言編程中的重要基礎(chǔ),需要的朋友可以參考下
    2015-12-12
  • C++ Opencv自寫函數(shù)實(shí)現(xiàn)膨脹腐蝕處理技巧

    C++ Opencv自寫函數(shù)實(shí)現(xiàn)膨脹腐蝕處理技巧

    這篇文章主要介紹了C++ Opencv 自寫函數(shù)實(shí)現(xiàn)膨脹腐蝕處理,本文通過示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10
  • C語言求解定積分的方法

    C語言求解定積分的方法

    這篇文章主要為大家詳細(xì)介紹了C語言求解定積分的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02

最新評(píng)論