中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C++快速排序算法代碼分享

發布時間:2021-09-09 18:51:43 來源:億速云 閱讀:189 作者:chen 欄目:編程語言

本篇內容介紹了“C++快速排序算法代碼分享”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

#include <iostream>
#include <algorithm>
#include <string>
#include <cctype>

struct example{
    int id;
    std::string name;
};

template <class T>

template <class T>

bool intCheck(int a, int b){
    return (a < b);
}

bool stringCheck(std::string a, std::string b){
    for(int i = 0; i < a.length(); i++)
        a[i] = tolower(a[i]);
    for(int i = 0; i < b.length(); i++)
        b[i] = tolower(b[i]);
    if(strcmp(a.c_str(), b.c_str()) >= 0)
        return false;
    else return true;
}

bool exampleCheck(example a, example b){
    if(strcmp(a.name.c_str(), b.name.c_str()) >= 0) return false;
    else return true;
}

    int iArray[] = { 2, 1, 56, 213, 2, 32, 32216, 14 };
    std::string sArray[] = { "Hello", "how are you?", "elephant", "aaah!", "zzzzz", "queen" };
    example structArray[] = { {1, "Joe"},
                              {4, "Billy"},
                              {2, "Zander"},
                              {3, "Tom"} };

    quickSort(iArray, 0, 7, intCheck);
    quickSort(sArray, 0, 5, stringCheck);
    quickSort(structArray, 0, 3, exampleCheck);

    std::cout << "Integers:" << std::endl;
    for(int i = 0; i < 8;i++)
        std::cout << 't' << iArray[i] << std::endl;

    std::cout << std::endl << "String:" << std::endl;
    for(int i = 0; i < 6;i++)
        std::cout << 't' << sArray[i] << std::endl;

    std::cout << std::endl << "Structure (By name):" << std::endl;
    for(int i = 0; i < 4;i++)
        std::cout << "t{ " << structArray[i].id << ", " << structArray[i].name << " }" << std::endl;

    std::cin.get();
    return 0;
}

template <class T>
     int pos = l;
     std::swap(uA[r], uA[pos]);
     if (l < r){
        std::swap(uA[r], uA[pos]);
        }
     return pos;
}

template <class T>
     if(r > l){
        int pos = partition( uA, l, r, less );
        quickSort( uA, l, pos-1, less);
        quickSort( uA, pos+1, r, less);
     }
}

“C++快速排序算法代碼分享”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

黄山市| 子长县| 通州市| 开江县| 镇坪县| 沐川县| 武乡县| 华坪县| 建德市| 吉木乃县| 波密县| 星子县| 且末县| 丹阳市| 甘洛县| 从江县| 乌兰县| 阳城县| 临汾市| 甘孜| 新闻| 伽师县| 天峻县| 丘北县| 汕头市| 长岛县| 灌南县| 丰宁| 台山市| 都昌县| 伊通| 湘阴县| 岳西县| 邛崃市| 天祝| 玉龙| 始兴县| 常熟市| 龙陵县| 于田县| 抚松县|