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

關于C++中定義比較函數(shù)的三種方法小結

 更新時間:2016年10月31日 13:53:23   投稿:jingxian  
下面小編就為大家?guī)硪黄P于C++中定義比較函數(shù)的三種方法小結。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

C++編程優(yōu)與Pascal的原因之一是C++中存在STL(標準模板庫)。STL存在很多有用的方法。

C++模板庫中的許多方法都需要相關參數(shù)有序,例如Sort()。顯然,如果你想對一個集合進行排序,你必須要知道集合中的對象,那個在前那個在后。因此,學會如何定義比較方法是非常重要的。

C++模板庫的許多容器需要相關類型有序,例如set<T> 和priority_queue<T>。

這篇文章旨在告訴大家如何為一個類定義一個排序方法,以便在STL容器或者方法中使用。 作為一個C++程序員,你應該知道這些方法。

如何定義排序?

簡而言之,為一個類定義排序,我們就可以知道類的任意兩個對象在排序的過程中誰在前誰在后。我們可以用一個方法來實現(xiàn),這個方法返回一個bool值表示誰排在前面。顯然,我們希望實現(xiàn)一個類似,f(x,y),這種形式的方法。它接收同一類型的對象作為兩個參數(shù),返回值則表明誰會出現(xiàn)在誰前面。

嚴格弱序化

幾乎所有的方法或容器都需要排序來滿足數(shù)學意義上的標準嚴格弱序化,否則這些方法或容器的行為將不可預知。

假設f(x,y)是一個比較函數(shù)。 如果該函數(shù)滿足如下條件則它是嚴格弱序化的。

1.f(x,x) = false;

2. if f(x,y) then !f(y,x)

3.if f(x,y) and f(y,z) then f(x,z)

4. if !f(x,y)&&!f(y,x) then x==y; if x==y and y==z then x==z;

看上去有點暈乎,不過不用擔心,只要你的比較方法能夠滿足對相等元素永遠返回false,那你的方法就滿足要求了。

三種實現(xiàn)方式:

1. 定義 < 操作符。

 使用這種方法可以使我們自定義的類能夠獲得與生俱來的排序能力。例如,如果有如下類:

struct Edge
{
int from,to ,weight;
};

因為要實現(xiàn)Kruskai算法,你希望圖中的所有邊依據(jù)權重按降序排列。 像這樣來定義 operator<:

struct Edge
{
    int from,to ,weight;
    bool operator <(Edge other) const
    {
        return weight>other.weight;
    }   
};  

你定義的方法必須按照如下方法聲明:

bool operator< (T other) const

注意: const關鍵字是必須的。

如果你不喜歡這種方式,比如,明明是要比較兩個對象,方法卻只有一個參數(shù)。你可以選擇如下方式:

 

struct Edge
{
  int from,to weight;
  friend bool operator<(Edge a,Edge b)
  {
    return a.weight>b.weight;
  }
};

STL的pair<T1,T2>就具有與生俱來的排序能力。兩個pair對象的比較這樣的:先比較第一個參數(shù),如果第一個參數(shù)相同再比較第二個參數(shù)。

所有內置類型都具有與生俱來的排序能力,這是由編譯器賦予的。

2. 自定義排序方法。

使用這種方式常常用在如下情形:

a.比較內置類型

b.不能修改需要比較的類型

c.除了類型自定義的比較方式以外的比較方法

簡單來說,一個比較方法接收兩個同類型的對象作為參數(shù)并且返回一個bool值,原型如下:

bool name(T a,T b);
 
3. 重載()操作符

我們可以將比較函數(shù)作為STL容器構造函數(shù)的第一個參數(shù),并且把函數(shù)類型作為模板參數(shù)。例如:

set<int,bool (*)(int,int)> s(cmp);

這樣做或多或少會讓人費解。那我們就來看看如何使用仿函數(shù)來消除你的疑惑吧。

我們需要定義一個新的類并重載()操作符。

vector<int> occurrences; 
struct cmp 
{ 
  bool operator()(int a, int b) 
  { 
    return occurrences[a] < occurrences[b];
  } 
};

現(xiàn)在我們就可以把這個類作為模板參數(shù)傳遞給STL容器了。

set<int, cmp> s;
 
priority_queue<int, vector<int>, cmp> pq;

STL也有一些內置的仿函數(shù),例如less<T>,greater<T>等。

仿函數(shù)可以通過初始化然后像普通函數(shù)一樣使用。最簡單的就是在仿函數(shù)后面加上()。

sort(data.begin(), data.end(), greater<int>());

以上就是小編為大家?guī)淼年P于C++中定義比較函數(shù)的三種方法小結全部內容了,希望大家多多支持腳本之家~

相關文章

  • 對比C語言中getc()函數(shù)和ungetc()函數(shù)的使用

    對比C語言中getc()函數(shù)和ungetc()函數(shù)的使用

    這篇文章主要介紹了對比C語言中getc()函數(shù)和ungetc()函數(shù)的使用,是C語言入門學習中的基礎知識,需要的朋友可以參考下
    2015-08-08
  • C++野指針的具體實現(xiàn)

    C++野指針的具體實現(xiàn)

    野指針就是指針指向的不是一個有效(合法)的地址,本文主要介紹了C++野指針的具體實現(xiàn),文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2024-03-03
  • Qt實現(xiàn)簡單動態(tài)時鐘

    Qt實現(xiàn)簡單動態(tài)時鐘

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)簡單動態(tài)時鐘,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • Opencv實現(xiàn)視頻播放與進度控制

    Opencv實現(xiàn)視頻播放與進度控制

    這篇文章主要為大家詳細介紹了Opencv實現(xiàn)視頻播放與進度控制,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 詳解C語言實現(xiàn)猜數(shù)字游戲

    詳解C語言實現(xiàn)猜數(shù)字游戲

    這篇文章主要為大家介紹了C語言實現(xiàn)猜數(shù)字游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助<BR>
    2022-01-01
  • C語言改造通訊錄操作詳解

    C語言改造通訊錄操作詳解

    這篇文章主要介紹了C語言文件操作改造通訊錄方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-01-01
  • C++帶頭雙向循環(huán)鏈表超詳細解析

    C++帶頭雙向循環(huán)鏈表超詳細解析

    帶頭雙向循環(huán)鏈表:結構最復雜,一般用在單獨存儲數(shù)據(jù)。實際中使用的鏈表數(shù)據(jù)結構,都是帶頭雙向循環(huán)鏈表。另外這個結構雖然結構復雜,但是使用代碼實現(xiàn)以后會發(fā)現(xiàn)結構會帶來很多優(yōu)勢,實現(xiàn)反而簡單
    2022-03-03
  • Qt編寫地圖綜合應用之繪制覆蓋物折線

    Qt編寫地圖綜合應用之繪制覆蓋物折線

    折線圖目前應用最廣的也是用來繪制各種軌跡,折線圖其實就是后面動態(tài)軌跡圖、飛機航線圖的前身,公用的一個方法addPolyline。本文將教大家如何通過QT實現(xiàn)覆蓋物折線圖,快來學習吧
    2021-12-12
  • C語言之二叉樹的遍歷

    C語言之二叉樹的遍歷

    這篇文章主要介紹了C語言中二叉樹的遍歷:前序、中序、后序,認識二叉樹結構最簡單的方式就是遍歷二叉樹,感興趣的小伙伴可以參考閱讀本文
    2023-03-03
  • C++ vector容器 find erase的使用操作:查找并刪除指定元素

    C++ vector容器 find erase的使用操作:查找并刪除指定元素

    這篇文章主要介紹了C++ vector容器 find erase的使用操作:查找并刪除指定元素,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-05-05

最新評論