输入若干个武将的信息,包括姓名、体力、智力和武力值,直到用户输入的人物姓名为‘#’ ,表示输入结束。再输入指标编号(1表示体力 2表示智力 3表示武力),根据该指标对所有将领进行从大到小排序,并将排序后的结果输出,每个信息之间用空格分隔。
输入说明:
‘#’之前的每一行都包含四个信息,分别是姓名、体力、智力、武力
;‘#’后一行的数字表示单项指标序号,如1表示按体力排序。
样例输入:
关羽 90 80 90
赵云 90 90 90
张飞 100 70 80
#
2
样例输出
赵云 90 90 90
关羽 90 80 90
输入说明:
‘#’之前的每一行都包含四个信息,分别是姓名、体力、智力、武力
;‘#’后一行的数字表示单项指标序号,如1表示按体力排序。
样例输入:
关羽 90 80 90
赵云 90 90 90
张飞 100 70 80
#
2
样例输出
赵云 90 90 90
关羽 90 80 90
张飞 100 70 80
#include<iostream>
#include<algorithm>
using namespace std;
class Cooler{
public:
char name[23];
int ti;
int zhi;
int wu;
};
bool cmp1(Cooler a,Cooler b){
return a.ti>b.ti;
}
bool cmp2(Cooler a,Cooler b){
return a.zhi>b.zhi;
}
bool cmp3(Cooler a,Cooler b){
return a.wu>b.wu;
}
int main(){
Cooler p[23];
int i=0;
char ch[23];
while(cin>>p[i].name && *p[i].name!='#'){
cin>>p[i].ti>>p[i].zhi>>p[i].wu;i++;
}
cout<<"请输入你想要比较的指标(1或2或3):"<<endl;
int n;
cin>>n;
switch(n){
case 1:sort(p,p+i,cmp1);break;
case 2:sort(p,p+i,cmp2);break;
case 3:sort(p,p+i,cmp3);break;
}
for(int j=0;j<i;j++)
cout<<p[j].name<<" "<<p[j].ti<<" "<<p[j].zhi<<" "<<p[j].wu<<endl;
return 0;
}