最厉害的学生(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;
}
相关推荐
big_rabbit05025 分钟前
[算法][力扣167]Two Sum II
算法·leetcode·职场和发展
会编程的土豆11 分钟前
Set 深度解析:去重、唯一性与你的智能抽屉
java·开发语言·后端·数据结构与算法
颜酱14 分钟前
二分图核心原理与判定算法
javascript·后端·算法
java1234_小锋32 分钟前
Java高频面试题:JVM内存为什么要分代?
java·开发语言·jvm
筱砚.33 分钟前
C++——lambda
开发语言·c++·算法
两个人的幸福online35 分钟前
php开发者 需要 协程吗
android·开发语言·php
Eward-an1 小时前
LeetCode 76. 最小覆盖子串(详细技术解析)
python·算法·leetcode·职场和发展
guygg881 小时前
基于ADMM的MRI-PET高质量图像重建算法MATLAB实现
开发语言·算法·matlab
小小程序员mono1 小时前
JS 与 Vue Router 导航方式对比
开发语言·javascript·vue.js
moonlight03041 小时前
类加载子系统
java·jvm·算法