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

C語(yǔ)言對(duì)結(jié)構(gòu)體數(shù)組按照某項(xiàng)規(guī)則進(jìn)行排序的實(shí)現(xiàn)過(guò)程探究

 更新時(shí)間:2023年02月01日 16:27:33   作者:36°熨斗的學(xué)習(xí)日記  
這篇文章主要介紹了C語(yǔ)言對(duì)結(jié)構(gòu)體數(shù)組按照某項(xiàng)規(guī)則進(jìn)行排序的實(shí)現(xiàn)過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧

這是基于qsort()函數(shù)進(jìn)行的簡(jiǎn)單排序。(附帶其他類型的數(shù)組使用qsort()進(jìn)行的排序)

前言

基于qsort()函數(shù)進(jìn)行的排序最有用的莫過(guò)于在此對(duì)于結(jié)構(gòu)體數(shù)組進(jìn)行排序了。此外,若能結(jié)合函數(shù)指針,更是能夠?qū)崿F(xiàn)“想降就降,想升就升”的美好局面。

一、qsort()函數(shù)

void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );(來(lái)源msdn)

base:傳過(guò)去的數(shù)組

num:數(shù)組中元素的個(gè)數(shù)

width:數(shù)組中每個(gè)元素有多大

compare():此函數(shù)指針是需要自己實(shí)現(xiàn)的、根據(jù)什么規(guī)則進(jìn)行的排序函數(shù)

二、compare()函數(shù)

須根據(jù)需要對(duì)于參數(shù)進(jìn)行指針類型的轉(zhuǎn)化。

若對(duì)字符型數(shù)組進(jìn)行排序,那就轉(zhuǎn)換成字符型指針。(char*)

若對(duì)整型數(shù)組進(jìn)行排序,那就轉(zhuǎn)換成整型指針。(int*)

若對(duì)浮點(diǎn)型數(shù)組進(jìn)行排序,那就轉(zhuǎn)換成浮點(diǎn)型指針。(float*)

若對(duì)結(jié)構(gòu)體數(shù)組的某項(xiàng)進(jìn)行排序,那就轉(zhuǎn)換成結(jié)構(gòu)體指針。(struct xxx*)

1.結(jié)構(gòu)體數(shù)組

返回的是兩個(gè)結(jié)構(gòu)體指針解引用后相比較的結(jié)果。

1)升序?qū)崿F(xiàn)

代碼如下(示例):

int Ascend(const void* p1, const void* p2)
{
	const stu* x = p1;
	const stu* y = p2;
	// 對(duì)于結(jié)構(gòu)體進(jìn)行二級(jí)排序:
	// 如果年齡相等,誰(shuí)成績(jī)高誰(shuí)在前面
	if (x->age == y->age)
	{
		return (x->score < y->score);
	}
	else
	{
		return (x->age < y->age);
	}
}

2)降序?qū)崿F(xiàn)

代碼如下(示例):

int Descend(const void* p1, const void* p2)
{
	const stu* x = p1;
	const stu* y = p2;
	// 對(duì)于結(jié)構(gòu)體進(jìn)行二級(jí)排序:
	// 如果年齡相等,誰(shuí)成績(jī)高誰(shuí)在前面
	if (x->age == y->age)
	{
		return (x->score < y->score);
	}
	else
	{
		return (x->age < y->age);
	}
}

2.整型數(shù)組

返回的是兩個(gè)int指針解引用后相減的結(jié)果。(用三目運(yùn)算符+大于小于號(hào)也可以)

為什么不直接返回a>b(a<b)?

如下圖:因?yàn)閝sort()在判斷時(shí)是需要判斷兩個(gè)參數(shù)誰(shuí)大誰(shuí)小,是需要一個(gè)正數(shù)或者負(fù)數(shù)的,但是直接返回a>b(a<b)的話,這個(gè)表達(dá)式的值只有0和非0,非0會(huì)被認(rèn)為是相等,從而不進(jìn)行交換。

1)升序?qū)崿F(xiàn)

代碼如下(示例):

void ArrComp(const void* p1, const void* p2)
{
	const int* x = p1;
	const int* y = p2;
	return *x - *y;
}

2)降序?qū)崿F(xiàn)

代碼如下(示例):

void ArrDescend(const void* p1, const void* p2)
{
	const int* x = p1;
	const int* y = p2;
	return *y - *x;
}

3.浮點(diǎn)型數(shù)組

返回的是兩個(gè)float指針解引用相減的結(jié)果,使用三目運(yùn)算符進(jìn)行判斷(目的是為了判斷大小后有個(gè)正負(fù))。

1)升序?qū)崿F(xiàn)

代碼如下(示例):

void FloatArrAscend(const void* p1, const void* p2)
{
	const float* x = p1;
	const float* y = p2;
	return *x > *y ? 1 : -1;
}

2)降序?qū)崿F(xiàn)

代碼如下(示例):

void FloatArrDescend(const void* p1, const void* p2)
{
	const float* x = p1;
	const float* y = p2;
	return *y < *x ? 1 : -1;
}

三、效果圖

總結(jié)

qsort()函數(shù)源碼在c庫(kù)中使用的是快排進(jìn)行的排序函數(shù),結(jié)合函數(shù)指針,可以實(shí)現(xiàn)快速地升、降序的排序。

到此這篇關(guān)于C語(yǔ)言對(duì)結(jié)構(gòu)體數(shù)組按照某項(xiàng)規(guī)則進(jìn)行排序的實(shí)現(xiàn)過(guò)程探究的文章就介紹到這了,更多相關(guān)C語(yǔ)言數(shù)組排序內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語(yǔ)言多種獲取字符串長(zhǎng)度的方法

    C語(yǔ)言多種獲取字符串長(zhǎng)度的方法

    這篇文章主要介紹了C語(yǔ)言多種獲取字符串長(zhǎng)度的方法,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++實(shí)現(xiàn)打印1到最大的n位數(shù)

    C++實(shí)現(xiàn)打印1到最大的n位數(shù)

    這篇文章主要介紹了C++實(shí)現(xiàn)打印1到最大的n位數(shù),并分析了實(shí)現(xiàn)代碼中語(yǔ)句的跳轉(zhuǎn)技巧,需要的朋友可以參考下
    2014-09-09
  • c++ vector模擬實(shí)現(xiàn)的全過(guò)程

    c++ vector模擬實(shí)現(xiàn)的全過(guò)程

    這篇文章主要給大家介紹了關(guān)于c++ vector的模擬實(shí)現(xiàn)過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • C語(yǔ)言 選擇排序算法詳解及實(shí)現(xiàn)代碼

    C語(yǔ)言 選擇排序算法詳解及實(shí)現(xiàn)代碼

    本文主要介紹C語(yǔ)言 選擇排序算法,這里對(duì)排序算法做了詳細(xì)說(shuō)明,并附代碼示例,有需要的小伙伴可以參考下
    2016-08-08
  • 深入解讀C語(yǔ)言中的符號(hào)常量EOF

    深入解讀C語(yǔ)言中的符號(hào)常量EOF

    這篇文章主要介紹了C語(yǔ)言中的符號(hào)常量EOF,文中還介紹了EOF的驗(yàn)證和打印方法,需要的朋友可以參考下
    2015-11-11
  • C語(yǔ)言中的線程信號(hào)控制詳解

    C語(yǔ)言中的線程信號(hào)控制詳解

    這篇文章主要通過(guò)一些示例為大家詳細(xì)介紹一下C語(yǔ)言中的線程信號(hào)控制,文中的示例代碼講解詳細(xì),對(duì)我們深入了解C語(yǔ)言有一定的幫助,感興趣的可以學(xué)習(xí)一下
    2023-02-02
  • NDK 數(shù)據(jù)結(jié)構(gòu)之隊(duì)列與棧等的實(shí)現(xiàn)

    NDK 數(shù)據(jù)結(jié)構(gòu)之隊(duì)列與棧等的實(shí)現(xiàn)

    這篇文章主要介紹了NDK 數(shù)據(jù)結(jié)構(gòu)之隊(duì)列與棧等的實(shí)現(xiàn)的相關(guān)資料,希望通過(guò)本文大家能理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • VS+Qt+Halcon 顯示圖片,實(shí)現(xiàn)鼠標(biāo)縮放、移動(dòng)圖片

    VS+Qt+Halcon 顯示圖片,實(shí)現(xiàn)鼠標(biāo)縮放、移動(dòng)圖片

    本篇博文記錄一下,用VS+Qt+Halcon實(shí)現(xiàn)對(duì)圖片的讀取以及鼠標(biāo)縮放,移動(dòng)(鼠標(biāo)事件調(diào)用了halcon自帶的算子)的過(guò)程。感興趣的可以了解一下
    2021-08-08
  • C++11線程、互斥量以及條件變量示例詳解

    C++11線程、互斥量以及條件變量示例詳解

    這篇文章主要介紹了C++11線程、互斥量以及條件變量,C++11增加了線程以及線程相關(guān)的類,很方便地支持了并發(fā)編程,使得編寫(xiě)多線程程序的可移植性得到了很大的提高,本文通過(guò)實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下
    2023-03-03
  • c++超細(xì)致講解引用

    c++超細(xì)致講解引用

    引用(reference)就是C++對(duì)C語(yǔ)言的重要擴(kuò)充。引用就是某一變量(目標(biāo))的一個(gè)別名,對(duì)引用的操作與對(duì)變量直接操作完全一樣
    2022-05-05

最新評(píng)論