一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - 如何使用VC庫函數中的快速排序函數

如何使用VC庫函數中的快速排序函數

2020-12-28 10:28C語言教程網 C/C++

下面呢,小編就為大家介紹一下VC中庫函數qsort()的用法。需要的朋友可以過來參考下

函數原型:
void qsort(void *base,size_t num,size_t width,
int (__cdecl *compare )(const void *, const void *) );

第一個是數組地址,第二是數組大小,第三個是數組中每個元素的字節數,最后一個是個函數指針,表示如何比較數組中的元素。

頭文件 #include <stdlib.h>
下面分別就int等整數數據,double等浮點數據,結構體和類,按指定方式這四種情況進行講解。

實例1、對int等整數數據進行排序

復制代碼 代碼如下:

int cmp(const void *x, const void *y)
{
 return *(int*)x - *(int*)y;
}
qsort(a, MAXN, sizeof(a[0]), cmp);


MAXN為數組大小,下同

 

實例2、對double等浮點數進行排序

復制代碼 代碼如下:

int cmpDouble(const void *x, const void *y)
{
 return (*(double*)x > *(double*)y ? 1 : -1);
}
qsort(a, n, sizeof(a[0]), cmpDouble);


實例3、對結構體,類等復雜數據進行排序

復制代碼 代碼如下:

struct Student
{
 char szName[30];
 int  nAge;
};


先對年齡排序,年齡相同再按姓名排序。

復制代碼 代碼如下:

int cmpStudent (const void *x, const void *y)
{   //先作下指針轉換,再按要求比較
 Student *pNodex = (Student*)x, *pNodey = (Student*)y;
 if (pNodex->nAge != pNodey->nAge)
  return pNodex->nAge - pNodey->nAge;
 else
  return strcmp(pNodex->szName, pNodey->szName);
}
qsort(a, n, sizeof(a[0]), cmpStudent);


實例4、按指定方式進行排序。
如對只有大小寫字母的字符串"AajkuKdYUBCDwyz"進行排序,要求大寫字母在前,小寫字母在后。

復制代碼 代碼如下:


int cmp1(const void *x, const void *y)
{
 char *pcx = (char*)x, *pcy = (char*)y;

 

 bool flag1 = *pcx >= 'A' && *pcx <= 'Z';
 bool flag2 = *pcy >= 'A' && *pcy <= 'Z';

 if(flag1 == flag2)    //如果都為大寫字母或都為小寫字母
  return *pcx - *pcy;
 else                  //否則,誰為大寫字母,誰的權值小。
  return flag1 ? -1 : 1;
}
int main()
{
 char szText[] = "AajkuKdYUBCDwyz";
 qsort(szText, strlen(szText), sizeof(szText[0]), cmp1);
 printf("%s\n", szText);
 return 0;
}

 

延伸 · 閱讀

精彩推薦
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
主站蜘蛛池模板: 亚洲高清中文字幕 | 欧美xxxxx性 欧美xxxbrazzers | 国产伦精品一区二区三区免 | 九九九九在线精品免费视频 | 免费观看全集 | 91青青草原 | 国产亚洲综合成人91精品 | 国产清纯91天堂在线观看 | 久久精品久久久久 | 青草青草伊人精品视频 | 999国产高清在线精品 | 国精品午夜dy8888狼人 | 国产剧情麻豆刘玥视频 | 午夜国产小视频 | 精品久久久久香蕉网 | 国产中文在线视频 | 亚洲 欧美 日本 国产 高清 | 欧美日韩中文字幕一区二区高清 | 秋葵视频成人 | 热热99 | 亚洲国产在线观看免费视频 | 成人特级毛片69免费观看 | 满城尽带黄金甲大胸片 | 国产按摩系列 | 男人网站视频 | 手机在线伦理片 | 国产一区二区视频在线观看 | 香蕉国产精品偷在线播放 | 欧美日韩色图 | 香蕉久久一区二区三区啪啪 | 国产欧美一区二区精品久久久 | 精品国产一级毛片大全 | 99在线播放| yy3341殇情影院理论片 | 国内精品露脸在线视频播放 | 国内老司机精品视频在线播出 | 99视频免费 | 国产偷啪视频一区 | 精品国产在天天线在线麻豆 | 免费在线视频一区 | 国产免费久久精品 |