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

C語言庫函數(shù)中qsort()的用法

 更新時間:2021年12月24日 09:12:57   作者:小小蔡很菜  
大家好,本篇文章主要講的是C語言庫函數(shù)中qsort()的用法,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽

qsort是庫函數(shù)提供的一種排序方法,我們就簡單1了解一下怎么去用,而不去深究它的庫函數(shù)是怎么寫的

qsort是庫函數(shù)中提供的一種能排序任何類型的數(shù)據(jù)的一種排序方法,思想是quick sort(快速排序),今天我聽鵬哥講指針,剛好引入了這一點,我就趁熱打鐵,總結(jié)一下該排序的用法

(一)void*? 的指針類型是什么?

void*類型的指針是能接受任何數(shù)據(jù)類型的地址,但是void*的指針類型是不能進行解引用操作的,也不能進行加減整數(shù)的操作,因為void*不知道它會占用多少個字節(jié)

#include <stdio.h>
int main()
{
int a=10;
char ch='w';
void* p=&a;
p=&ch;
return 0;
}

(二)void?qsort(void*,?size_t,?size_t,?int?(?*?)(const?void?*?,??const?void?*??))? 該怎么使用該庫函數(shù)?

我們先來看看qsort()內(nèi)部有些什么參數(shù),參數(shù)類型是什么,該怎么用。

void?qsort(void* base,?size_t,?size_t,?int?(?*?)(const?void?*?,??const?void?*??))

可以看出共有四個參數(shù)

1.void1* base:待排序數(shù)組的首地址,可直接輸入待排序數(shù)組名,也可使用指針指向該數(shù)組

2.size_t num:數(shù)組的長度,假如有數(shù)組int arr[ ]用sz=sizeof(arr)/sizeof(arr[0])來計算數(shù)組的長度

3.size_t width:數(shù)組中的元素所占字節(jié),可用sizeof(arr[0])來計算單個元素的字節(jié)數(shù)

4.

int (*cmp)(const void* e1,const void* e2)
{
return  *(int*)e1 - *(int*)e2;//因為void*類型的指針不能進行加減操作,所以先將e1,e2進行強制類型轉(zhuǎn)換,轉(zhuǎn)為int*,然后對其進行解引用
//不同的情形可以根據(jù)不同的比較方式來寫入這個函數(shù)
//例如,字符串進行比較的時候,可以引用strcmp()這個函數(shù)
}

:從這個形式可看出這是一個函數(shù)指針類型的參數(shù),意味著將要調(diào)用一個函數(shù),而這個函數(shù)在庫函數(shù)中表示進行排序的方式

這里簡單解釋一下這個函數(shù)指針的意義

int 表示返回的是一個int類型的值

cmp表示函數(shù)名,*cmp表示指向這個函數(shù)

(const void* e1,const void* e2)這里·的e1,e2表示將要進行比較的兩個元素,然后將兩個元素的地址傳到函數(shù)里,const表示無法修改指針指向的值

(三)使用qsort()來排序不同類型的數(shù)據(jù)

1.整型

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
int cmp_int(const void* e1, const void* e2)
{
	return *(int*)e1 - *(int*)e2;
}
int main()
{
	int arr[10] = { 3,4,1,2,7,8,9,5,6,0 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_int);
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
 
	return 0;
}

2.浮點型

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
int cmp_float(const void* e1, const void* e2)
{
	return (int)(*(int*)e1 - *(int*)e2);
    
}
int main()
{
	float arr[6] = { 2.0,2.3,4.5,5.0,8.0,9.0 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_float);
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%.2f ", arr[i]);
	}
	return 0;
}

3.結(jié)構(gòu)體數(shù)據(jù)類型(數(shù)字,字符串)

下面我創(chuàng)建了一個機構(gòu)體,我先以結(jié)構(gòu)體中年齡排序

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
 
struct stu
{
	char name[20];
	int age;
	char sex[10];
};
int cmp_stu_by_age(const void* e1, const void* e2)//按年齡排序
{
	return ((struct stu*)e1)->age- ((struct stu*)e2)->age;
}
int main()
{
	struct stu s[3] = { {"zhangsan",30,"man"},{"lisi",20,"man"},{"ruhua",18,"woman"}};
	int sz = sizeof(s) / sizeof(s[0]);
	qsort(s, sz, sizeof(s[0]), cmp_stu_by_age);
	int i;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d %s\n", s[i].name, s[i].age, s[i].sex);
	}
	return 0;
}

?然后以姓名排序

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
struct stu
{
	char name[20];
	int age;
	char sex[10];
};
int cmp_stu_by_name(const void* e1, const void* e2)
{
	return strcmp(((struct stu*)e1)->name, ((struct stu*)e2)->name);
}
 
//int cmp_stu_by_age(const void* e1, const void* e2)
//{
//	return ((struct stu*)e1)->age- ((struct stu*)e2)->age;
//}
int main()
{
	struct stu s[3] = { {"zhangsan",30,"man"},{"lisi",20,"man"},{"ruhua",18,"woman"}};
	int sz = sizeof(s) / sizeof(s[0]);
	qsort(s, sz, sizeof(s[0]), cmp_stu_by_name);
	int i;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d %s\n", s[i].name, s[i].age, s[i].sex);
	}
	return 0;
}

?總結(jié):

今天的qsort就這樣了,關(guān)鍵在于

int cmp_int(const void* e1, const void* e2)
{
return *(int*)e1 - *(int*)e2;
}這一部分的書寫與理解,然后就是孰能生巧,多練習(xí)就會知道怎么用了

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

相關(guān)文章

  • C語言實現(xiàn)單鏈表逆序與逆序輸出實例

    C語言實現(xiàn)單鏈表逆序與逆序輸出實例

    這篇文章主要介紹了C語言實現(xiàn)單鏈表逆序與逆序輸出,是數(shù)據(jù)結(jié)構(gòu)與算法中比較基礎(chǔ)的重要內(nèi)容,有必要加以牢固掌握,需要的朋友可以參考下
    2014-08-08
  • VC程序設(shè)計小技巧20例

    VC程序設(shè)計小技巧20例

    這篇文章主要介紹了VC程序設(shè)計小技巧20例,需要的朋友可以參考下
    2014-07-07
  • C++實現(xiàn)LeetCode(199.二叉樹的右側(cè)視圖)

    C++實現(xiàn)LeetCode(199.二叉樹的右側(cè)視圖)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(199.二叉樹的右側(cè)視圖),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C語言類型轉(zhuǎn)換與常量的細(xì)節(jié)深入理解探究

    C語言類型轉(zhuǎn)換與常量的細(xì)節(jié)深入理解探究

    這篇文章主要為大家介紹了C?語言類型轉(zhuǎn)換與常量的細(xì)節(jié)深入理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • C語言學(xué)好遞歸看這一篇就夠了

    C語言學(xué)好遞歸看這一篇就夠了

    遞歸指的是在函數(shù)的定義中使用函數(shù)自身的方法,舉個例子: 從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,廟里有個老和尚,正在給小和尚講故事呢!故事是什么呢?"從前有座山,山里有座廟,循環(huán)下去
    2021-10-10
  • C語言實現(xiàn)洗牌發(fā)牌小程序

    C語言實現(xiàn)洗牌發(fā)牌小程序

    這篇文章主要介紹了C語言實現(xiàn)洗牌發(fā)牌小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • c++中虛函數(shù)的實現(xiàn)詳解

    c++中虛函數(shù)的實現(xiàn)詳解

    眾所周知探索c++對象內(nèi)部的實現(xiàn)是一件非常有趣的事情,虛函數(shù)在c++中的實現(xiàn)機制就是用虛表和虛指針,但是具體是怎樣的呢?下面這篇文章就來給大家實際檢驗一下 Visual Studio 2013 編譯器在無優(yōu)化條件下,虛函數(shù)的實現(xiàn)。有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • c語言float類型小數(shù)點后位數(shù)

    c語言float類型小數(shù)點后位數(shù)

    在本篇文章里小編給大家整理了關(guān)于c語言float類型小數(shù)點后面有幾位的相關(guān)知識點,需要的朋友們可以學(xué)習(xí)下。
    2020-02-02
  • 常用的C語言編程工具匯總

    常用的C語言編程工具匯總

    c語言編程軟件適于編寫系統(tǒng)軟件,是學(xué)習(xí)編程的同學(xué)們的必備軟件。c語言一種非常強大的計算機語言,應(yīng)用非常廣泛,不僅僅是在軟件開發(fā)上,而且各類科研都會用到c語言。今天小編給大家匯總下C語言的編程工具
    2018-01-01
  • 用C++實現(xiàn),將一句話里的單詞進行倒置的方法詳解

    用C++實現(xiàn),將一句話里的單詞進行倒置的方法詳解

    本篇文章是對用C++實現(xiàn),將一句話里的單詞進行倒置的方法進行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05

最新評論