最厉害的学生(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;
}
相关推荐
刀法如飞1 小时前
TypeScript 数组去重的 20 种实现方式,哪一种你还不知道?
前端·javascript·算法
無限進步D1 小时前
Java 面向对象高级 接口
java·开发语言
tankeven2 小时前
C++ 智能指针
c++
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章66-直线夹角
图像处理·人工智能·opencv·算法·计算机视觉
AC赳赳老秦2 小时前
接口测试自动化:用 OpenClaw 对接 Postman,实现批量回归测试、测试报告自动生成与推送
java·人工智能·python·算法·elasticsearch·deepseek·openclaw
两年半的个人练习生^_^2 小时前
Java日志框架和使用、日志记录规范
java·开发语言·开发规范
_风满楼2 小时前
TDD实战-会议室冲突检测的红绿重构循环
前端·javascript·算法
pq2173 小时前
java实现遗传算法
算法
杨凯凡3 小时前
【032】排查入门:jstack、heap dump、Arthas 初识
java·开发语言·后端
其实防守也摸鱼3 小时前
无线网络安全--实验 规避WLAN验证之发现隐藏的SSID
java·开发语言·网络·安全·web安全·智能路由器·无线网络安全