C ++中的结构排序
在这里,我们将看到如何在C++中使用某些条件对结构的某些成员变量进行排序。在此示例中,我们将采用一种称为book的结构。这本书将包含名称,页数和价格。我们将根据价格对其进行排序。
为了比较两个结构,我们必须定义一个函数。此功能会将它们与这些参数进行比较。在排序函数内部使用此比较函数对值进行排序。
示例
#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