激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - C/C++ - C++ 關(guān)于STL中sort()對struct排序的方法

C++ 關(guān)于STL中sort()對struct排序的方法

2020-11-22 23:06C++教程網(wǎng) C/C++

本篇文章介紹了,關(guān)于STL中sort()對struct排序的方法。需要的朋友參考下

  前言

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

  開發(fā)環(huán)境:QtCreator2.5.1+OpenCV2.4.3

  實驗基礎(chǔ)

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

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

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


	
復(fù)制代碼 代碼如下:
/*按照降序排列*/ bool compare(const PAIR &x, const PAIR &y) {     return x.point_value > y.point_value; }

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

復(fù)制代碼 代碼如下:
/*按照降序排列*/ bool operator<(const PAIR &x, const PAIR &y) {     return x.point_value > y.point_value; }

  則會報錯如下錯誤:

  C++ 關(guān)于STL中sort()對struct排序的方法

  std::sort因為函數(shù)參數(shù)不明確,所以無法推導(dǎo)出模板參數(shù)等.

 

  實驗結(jié)果

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

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

  C++ 關(guān)于STL中sort()對struct排序的方法

  實驗代碼及注釋

  main.cpp:

復(fù)制代碼 代碼如下:

#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 << "排序的結(jié)果為:" << endl;     for(vector<PAIR>::iterator it = vec.begin(); it != vec.end(); ++it) {         cout << it->point << endl;     }

    return ; }

 

  實驗總結(jié)

  std::sort()函數(shù)的功能很強(qiáng)大,且可以對類,結(jié)構(gòu)體等元素進(jìn)行排序。

延伸 · 閱讀

精彩推薦
  • C/C++C語言中炫酷的文件操作實例詳解

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

    內(nèi)存中的數(shù)據(jù)都是暫時的,當(dāng)程序結(jié)束時,它們都將丟失,為了永久性的保存大量的數(shù)據(jù),C語言提供了對文件的操作,這篇文章主要給大家介紹了關(guān)于C語言中文件...

    針眼_6702022-01-24
  • C/C++c++ 單線程實現(xiàn)同時監(jiān)聽多個端口

    c++ 單線程實現(xiàn)同時監(jiān)聽多個端口

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

    源之緣11542021-10-27
  • C/C++C語言實現(xiàn)電腦關(guān)機(jī)程序

    C語言實現(xiàn)電腦關(guān)機(jī)程序

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

    xiaocaidayong8482021-08-20
  • C/C++C++之重載 重定義與重寫用法詳解

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

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

    青山的青6062022-01-04
  • C/C++學(xué)習(xí)C++編程的必備軟件

    學(xué)習(xí)C++編程的必備軟件

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

    謝恩銘10102021-05-08
  • C/C++深入理解goto語句的替代實現(xiàn)方式分析

    深入理解goto語句的替代實現(xiàn)方式分析

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

    C語言教程網(wǎng)7342020-12-03
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數(shù)使用

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

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

    spring-go5642021-07-02
  • C/C++C/C++經(jīng)典實例之模擬計算器示例代碼

    C/C++經(jīng)典實例之模擬計算器示例代碼

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

    jia150610152021-06-07
主站蜘蛛池模板: 国产精品999在线观看 | 青青草成人av | 在线成人免费av | 天天舔夜夜操 | 国产精品a一 | 热久久成人 | hd极品free性xxx护士人 | 91网站在线观看视频 | 玖玖精品视频在线 | 久久精品欧美视频 | 国产一级毛片国语版 | 97精品国产高清在线看入口 | 成人福利在线观看 | 一级电影免费看 | av免费片| www.91sao | 国产噜噜噜噜久久久久久久久 | 国产无遮挡一级毛片 | 久久久久久中文字幕 | 蜜桃麻豆视频 | 中文字幕国产日韩 | 日本aⅴ在线 | 91精品国产91久久久 | 成人在线免费观看网址 | 精品视频 久久久 | 精品欧美一区二区精品久久 | 欧美18一19sex性护士农村 | 91精品老司机 | 免费黄色一级网站 | 免费在线性爱视频 | 久久久久一区二区三区 | 在线免费av观看 | 国产精品久久久久久久娇妻 | 性欧美极品xxxx欧美一区二区 | 伊人一二三四区 | 国产精品久久久久久久久久尿 | 羞羞视频免费网站 | 久久精品视频一区 | 久久网一区二区 | 日本欧美一区二区三区视频麻豆 | 特黄一区二区三区 |