C++ 中的結構排序


在這篇文中,我們將瞭解如何在 C++ 中透過結構的一些成員變數的一些條件對結構進行排序。在本例中,我們將使用一個名為 Book 的結構。該 Book 將包含名稱、頁數和價格。我們將根據價格對它們進行排序。

要比較兩個結構,我們必須定義一個函式。此函式將按照這些引數對它們進行比較。此比較函式在 sort 函式內部用於對值進行排序。

範例程式碼

#include <iostream>
#include<algorithm>
using namespace std;
struct book {
   string title;
   int pages;
   float price;
};
bool compareBook(book b1, book b2) {
   if(b1.price < b2.price) {
      return true;
   } return false;
}
main() {
   book book_arr[5];
   book_arr[0].title = "C Programming";
   book_arr[0].pages = 260;
   book_arr[0].price = 450;
   book_arr[1].title = "DBMS Guide";
   book_arr[1].pages = 850;
   book_arr[1].price = 775;
   book_arr[2].title = "Learn C++";
   book_arr[2].pages = 350;
   book_arr[2].price = 520;
   book_arr[3].title = "Data Structures";
   book_arr[3].pages = 380;
   book_arr[3].price = 430;
   book_arr[4].title = "Learn Python";
   book_arr[4].pages = 500;
   book_arr[4].price = 300;
   sort(book_arr, book_arr + 5, compareBook);
   for(int i = 0; i<5; i++) {
      cout << book_arr[i].title << "\t\t" << book_arr[i].pages << "\t\t" <<
         book_arr[i].price << endl;
   }
}

輸出

Learn Python 500 300
Data Structures 380 430
C Programming 260 450
Learn C++ 350 520
DBMS Guide 850 775

更新時間: 2019-07-30

1K+ 瀏覽次數

開啟你的 職業生涯

完成課程獲取認證

開始
廣告
© . All rights reserved.