Practice3_7_vector_sort_struct_gold_silver_bronze_playerName3

 

下面這個就是把結構體中內置的operator單獨拿出來,做爲比較器實現的方式。ios

 1 // Practice3_vector_sort_struct.cpp : 定義控制檯應用程序的入口點。
 2 //
 3 
 4 #include "stdafx.h"
 5 #include <vector>
 6 #include <algorithm>
 7 #include <iostream>
 8 #include <ctime>
 9 #include <stdio.h>
10 #include <string>
11 
12 using namespace std;
13 
14 struct ScoreStruct
15 {
16     string name; 
17     unsigned int gold;
18     unsigned int silver;
19     unsigned int bronze;
20 };
21 
22 /* 把結構體中內置的operator單獨拿出來,做爲比較器實現*/
23 bool comparatorScoreStruct(const ScoreStruct &ss1, const ScoreStruct &ss2)
24 {
25         int temp = ss1.name.compare(ss2.name);
26         if(ss1.gold != ss2.gold)//首先按照金銀銅牌數降序,若是都相等,則按照姓名升序
27         {
28             return ss1.gold > ss2.gold;
29         }
30 
31         if(ss1.silver != ss2.silver)
32         {
33             return ss1.silver > ss2.silver;
34         }
35 
36         if(ss1.bronze != ss2.bronze)
37         {
38             return ss1.bronze > ss2.bronze;
39         }
40         
41         if(temp <0)
42         {
43             return 1;
44         }
45         return 0;//不管如何,要保證最後要有一個return的
46 }
47 
48 string strs[4] = { "tencent", "google","alibaba", "facebook"};
49 
50 void initVector(vector<ScoreStruct> &vec, unsigned int size)
51 {
52     srand(unsigned(time(NULL)));
53     for(unsigned int i =0; i < size; i++)
54     {
55         //char buff[32] = {0};
56         int goldCount = 6;
57         int silverCount = 6;
58         int bronzeCount = 6;
59         //sprintf(buff, "%d", chineseScore);
60         ScoreStruct ss = {strs[i], goldCount, silverCount, bronzeCount};
61         /*
62         ScoreStruct ss = {"0", 0};
63         strcpy(ss.name, buff);
64         ss.score = randNum;
65         */
66         vec.push_back(ss);
67     }
68 }
69 
70 void printVector(vector<ScoreStruct> vec)
71 {
72     vector<ScoreStruct>::iterator it = vec.begin();
73     for(; it != vec.end();++it)
74     {
75         cout << it->name << "," << it->gold << "," << it->silver << "," << it->bronze << " ";
76     }
77     cout<<endl;
78 }
79 
80 int _tmain(int argc, _TCHAR* argv[])
81 {
82     vector<ScoreStruct> vect;
83     initVector(vect, 4);
84     cout<<"before sort"<<endl;
85     printVector(vect);
86     sort(vect.begin(), vect.end(), comparatorScoreStruct);//與上個例子不一樣的是,多了一個比較器參數
87     cout<<"after sort"<<endl;
88     printVector(vect);
89     return 0;
90 }

before sort
tencent,6,6,6 google,6,6,6 alibaba,6,6,6 facebook,6,6,6
after sort
alibaba,6,6,6 facebook,6,6,6 google,6,6,6 tencent,6,6,6google

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息