模擬實(shí)現(xiàn)冒泡排序qsort

  • 調(diào)用函數(shù)庫中的qsort
#include<stdio.h>
#include <string.h>
#include<stdlib.h>

struct Stu
{
    char name[20];
    int age;
};

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

int cmp_stu_name(const void*e1, const void*e2)
{
    return strcmp((*(struct Stu*)e1).name, (*(struct Stu*)e2).name);
}

int main()
{
    int i = 0;
    int arr[] = {1,3,5,7,9,2,4,6,8,0};
    struct Stu arr2[] = { {"zhangsan",20}, {"lisi",45}, {"wangwu",12} };
    qsort(arr,sizeof(arr)/sizeof(arr[0]),sizeof(arr[0]),cmp_int);
    qsort(arr2, sizeof(arr2) / sizeof(arr2[0]), sizeof(arr2[0]), cmp_stu_name);

    for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
    {
        printf("%d ", arr[i]);
    }

    printf("\n------------------------------------\n");

    for (i = 0; i < sizeof(arr2) / sizeof(arr2[0]); i++)
    {
        printf("%s ", arr2[i].name);
    }

    return 0;

}

運(yùn)行結(jié)果:
系統(tǒng)冒泡.png

————————————————————————————————————
分析qsort函數(shù):

void qsort( void *base, size_t num, size_t width, int (__cdecl *compare )(const void *elem1, const void *elem2 ) );

base----Start of target array----目標(biāo)數(shù)組起始地址
num----Array size in elements----元素個(gè)數(shù)
width-----Element size in bytes----元素的大?。▎挝唬鹤止?jié))
compare----Comparison function----比較函數(shù)
elem1----Pointer to the key for the search----指針指向要比較的元素的地址
elem2--Pointer to the array element to be compared with the key--同上_

————————————————————————————————————

  • 模擬實(shí)現(xiàn)qsort
#define _CRT_SECURE_N0_WARNINGS 1
#include<stdio.h>
#include <string.h>
#include<stdlib.h>


struct Stu
{
    char name[20];
    int age;
};

 //一個(gè)字節(jié)一個(gè)字節(jié)的交換
void Swap(char *buf1,char *buf2,int width)
{
    int i = 0;
    for (i = 0; i < width; i++)
    {
        char tmp = *(buf1 + i);
        *(buf1 + i) = *(buf2 + i);
        *(buf2 + i) = tmp;
    }
}

void bubble_sort(void *base, int sz, int width, int(*cmp)(const void*e1, const void*e2))
{
    int i = 0;
    for (i = 0; i < sz - 1; i++)
    {
        int j = 0;
        for (j = 0; j < sz - 1 - i; j++)
        {
            if (cmp((char*)base+j*width,(char*)base+(j+1)*width)>0)//傳參 每個(gè)元素的地址
            {
                //交換
                Swap((char*)base + j*width, (char*)base + (j + 1)*width,width);
            }
        }
    }

}



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

int cmp_stu_name(const void*e1, const void*e2)
{
    return strcmp((*(struct Stu*)e1).name, (*(struct Stu*)e2).name);
}

int cmp_stu_age(const void*e1, const void*e2)
{
    return (((struct Stu*)e1)->age-((struct Stu*)e2)->age);
}


int main()
{
    int i = 0;
    int arr[] = {1,3,5,7,9,2,4,6,8,0};
    struct Stu arr2[] = { {"zhangsan",20}, {"lisi",45}, {"wangwu",12} };

    bubble_sort(arr,sizeof(arr)/sizeof(arr[0]),sizeof(arr[0]),cmp_int);
    for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
    {
        printf("%d ", arr[i]);
    }
    printf("\n------------------------------------\n");


    bubble_sort(arr2, sizeof(arr2) / sizeof(arr2[0]), sizeof(arr2[0]), cmp_stu_name);
    for (i = 0; i < sizeof(arr2) / sizeof(arr2[0]); i++)
    {
        printf("%s ", arr2[i].name);
    }
    printf("\n------------------------------------\n");


    bubble_sort(arr2, sizeof(arr2) / sizeof(arr2[0]), sizeof(arr2[0]), cmp_stu_age);
    for (i = 0; i < sizeof(arr2) / sizeof(arr2[0]); i++)
    {
        printf("%s ", arr2[i].name);
    }
    printf("\n------------------------------------\n");


    return 0;

}

運(yùn)行結(jié)果:
模擬冒泡.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Lua 5.1 參考手冊(cè) by Roberto Ierusalimschy, Luiz Henrique de F...
    蘇黎九歌閱讀 14,238評(píng)論 0 38
  • rljs by sennchi Timeline of History Part One The Cognitiv...
    sennchi閱讀 7,841評(píng)論 0 10
  • 如果你有那么一點(diǎn)愛我 你會(huì)在我說請(qǐng)假去醫(yī)院的時(shí)候送來禮貌性的問候 如果你有那么一點(diǎn)愛我 你會(huì)在我們一起出去唱歌很晚...
    做一杯冷靜得水閱讀 292評(píng)論 0 0
  • 再多的贊美也表達(dá)不完我對(duì)你的愛 我的母親 你那么樸素 那么真誠 我怕物質(zhì)你說浪費(fèi) 我怕金錢你說不需 我真不知道 我...
    等愛的貓閱讀 410評(píng)論 9 17
  • 每天哪怕很少一點(diǎn),也要在創(chuàng)造性的工作上下功夫。但若放長維度,就會(huì)發(fā)生巨大的變化。 無論多么渺小的工作都要積極的去做...
    銳風(fēng)鈴閱讀 306評(píng)論 0 0

友情鏈接更多精彩內(nèi)容