每日练题打卡
今天在索要注意的是当发现一个个体中包含多个元素时,可以考虑用结构体去解决,今天也学会了用sort函数去给结构体排序,简化了步骤。笔记:
#include<iostream>
#include<algorithm>
using namespace std;
struct student{
int math,chinese,english;
int sum;
int id;
}s[1000];
int w_comp(const student &a,const student &b){
if(a.sum!=b.sum) return a.sum>b.sum;
if(a.sum==b.sum){
if(a.chinese==b.chinese){
return a.id<b.id;
}
if(a.chinese!=b.chinese) return a.chinese>b.chinese;
}
}
int main(){
int n;
cin>>n;
for(int i=0;i<n;i++){
cin>>s[i].chinese>>s[i].math>>s[i].english;
s[i].sum=s[i].chinese+s[i].math+s[i].english;
s[i].id=i+1;
}
sort(s,s+n,w_comp);
for(int i=0;i<n;i++){
}
for(int i=0;i<5;i++){
cout<<s[i].id<<" "<<s[i].sum<<endl;
}
}
这是今天所收获的!
加油!## 标题