最厉害的学生(c++题解)

题目描述

现有 N 名同学参加了期末考试,并且获得了每名同学的信息:姓名(不超过 8 个字符的仅有英文小写字母的字符串)、语文、数学、英语成绩(均为不超过 150 的自然数)。总分最高的学生就是最厉害的,请输出最厉害的学生各项信息(姓名、各科成绩)。如果有多个总分相同的学生,输出靠前的那位。

输入格式

第一行输入一个正整数 N,表示学生个数。

第二行开始,往下 N 行,对于每一行首先先输入一个字符串表示学生姓名,再输入三个自然数表示语文、数学、英语的成绩。均用空格相隔。

输出格式

输出最厉害的学生。

输入输出样例

输入 #1复制

复制代码
3
senpai 114 51 4
lxl 114 10 23
fafa 51 42 60

输出 #1复制

复制代码
senpai 114 51 4

说明/提示

数据保证, 10001≤N≤1000,姓名为长度不超过 8 的字符串,语文、数学、英语成绩均为不超过 150 的自然数。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
struct node{结构体数组记录每一个人的名字好各科分数
	string name;
	int x,y,z;
}a[1000005];
int main(){
	int n,ans=-10000,m,cnt;ans记录当前最高分
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i].name;
		cin>>a[i].x>>a[i].y>>a[i].z;
		m=a[i].x+a[i].y+a[i].z;m记录每一个人的总分
		if(m>ans){与最高分对比更新
		    cnt=i;cnt记录最高分的下标
		    ans=m;
		}
	}
	cout<<a[cnt].name<<" "<<a[cnt].x<<" "<<a[cnt].y<<" "<<a[cnt].z;
}
相关推荐
JieE2123 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
clint4562 天前
C++进阶(1)——前景提要
c++