国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++ 關于STL中sort()對struct排序

2020-02-24 14:32:48
字體:
來源:轉載
供稿:網友

  一直沒有系統去看過c++,因為懂得一些c的基本語法,在實際編程中用到c++,只能用到哪些看哪些,發現這樣雖然能夠完成大部分工作,但是有時候效率實在太低,比如說這節要講的Std::sort()函數的使用,調了半天才調通。開通c/c++序列博客是記錄在使用c++中一些難題,避免以后重犯錯,當然以后會盡量擠出時間來較系統學習下c++。

  開發環境:QtCreator2.5.1+OpenCV2.4.3

  實驗基礎

  首先來看看std中的快速排序算法sort的使用方法:

  template <class RandomAccessIterator, class Compare>?void sort ( RandomAccessIterator first, RandomAccessIterator last, Compare comp );

  這是一個帶模板的函數,參數1和2表示需要排序的元素在隨機迭代器的起始位置和結束位置,其迭代器指向的數據類型可以自己定義,常見的數據類型包括結構體,vector,類等都可以被使用。參數comp是用來決定所采用的排序是升序還是逆序的,默認情況下是升序排列。但是這種默認情況的優勢是處理迭代器指向的元素為普通的數據類型,比如說整型,字符型等。如果指向的數據類型為類或者結構體,然后使用該類或者結構體中的某個元素進行排序,這時候需要自己定義排序的重載符號”<”。比如說在本次實驗中該重載符號的定義為:

?
?

/*按照降序排列*/
bool compare(const PAIR &x, const PAIR &y)
{
??? return x.point_value > y.point_value;
}

  如果將comp定義為一個函數(網上好像很多都是用這種類似的函數),比如說該函數如下:
?

/*按照降序排列*/
bool operator<(const PAIR &x, const PAIR &y)
{
??? return x.point_value > y.point_value;
}

  則會報錯如下錯誤:

  

  std::sort因為函數參數不明確,所以無法推導出模板參數等.

?

  實驗結果

  本次實驗是基于這樣一個問題的:有一些坐標點集合(2d的坐標點,坐標點之間沒有重復),每個坐標點對應一個數,現在需要對這些數排序從而達到對這些坐標點排序。有嘗試過把點的坐標和它對應的值放在map中,然后對map中的元素用std::sort()進行排序,但是由于開始沒有發現那個重載符號的使用,所以沒有調試成功。現在直接不用map了,而是用vector,vector里面放的是帶有坐標點和其對應值的struct。

  本次實驗是在vector中存入3個結構體對象,每個結構體中放入一個二維點和它對應的值,然后采用sort()對齊排序,排序結果如下:

  

  實驗代碼及注釋

  main.cpp:

?

#include <iostream>
#include <vector>
#include <map>
#include <algorithm>
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>

?

using namespace std;
using namespace cv;

typedef struct
{
??? cv::Point point;
??? long point_value;
} PAIR;

/*按照降序排列*/
bool operator<(const PAIR &x, const PAIR &y)
{
??? return x.point_value > y.point_value;
}

///*按照降序排列*/
//bool compare(const PAIR &x, const PAIR &y)
//{
//??? return x.point_value > y.point_value;
//}

void main()
{
??? PAIR pair1, pair2, pair3;
??? std::vector<PAIR> vec;
??? pair1.point = Point(10, 20);
??? pair1.point_value = 100;
??? pair2.point = Point(70, 30);
??? pair2.point_value = 99;
??? pair3.point = Point(44, 76);
??? pair3.point_value = 101;

??? vec.push_back(pair1);
??? vec.push_back(pair2);
??? vec.push_back(pair3);
//??? std::sort(vec.begin(), vec.end(), compare);
??? std::sort(vec.begin(), vec.end());
??? cout << "排序的結果為:" << endl;
??? for(vector<PAIR>::iterator it = vec.begin(); it != vec.end(); ++it) {
??????? cout << it->point << endl;
??? }

??? return ;
}

?

  實驗總結

  std::sort()函數的功能很強大,且可以對類,結構體等元素進行排序。如果還有其他疑問,歡迎補充,有任何問題也可以與武林編輯一起討論。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南江县| 上思县| 雷州市| 民丰县| 高平市| 疏附县| 衡南县| 黑山县| 临武县| 宣威市| 吉水县| 商河县| 溆浦县| 志丹县| 兴城市| 南安市| 普定县| 驻马店市| 锡林郭勒盟| 邢台市| 区。| 和田市| 上虞市| 长武县| 繁峙县| 五河县| 贵南县| 木里| 乌兰浩特市| 扬中市| 新蔡县| 贺州市| 溆浦县| 威海市| 汶上县| 盈江县| 广平县| 南京市| 临朐县| 灌南县| 镇赉县|