c++找最高成绩

根据给定的程序,写成相关的成员函数,完成指定功能。

函数接口定义:

定义max函数,实现输出最高成绩对应的学号以及最高成绩值。

裁判测试程序样例:

复制代码
#include <iostream>
using namespace std;
class Student
 {public:
   Student(int n,float s):num(n),score(s){}
   int num;
   float score;
 };

int main()
{Student stud[5]={
  Student(101,78.5),Student(102,85.5),Student(103,98.5),
  Student(104,100.0),Student(105,95.5)};
 void max(Student* );
 Student *p=&stud[0];
 max(p);
 return 0; 
 }
/* 请在这里填写答案 */

输入样例:

复制代码

输出样例:

复制代码
104 100

思路:

cpp 复制代码
void max(Student* p)    //接受一个指向Student类型的指针p作为参数。
{
 Student *max, *p1;   //定义了两个指向Student类型的指针变量max和p1。
 max = p;            //将max指针初始化为传入的p指针,即假设第一个学生的分数就是目前找到的最高分。
 for(p1 = p+1; p1 < p+5; p1++)    //从p+1开始(即第二个学生),直到p+4(即第五个学生)
    if(max->score < p1->score){   //如果当前max指向的学生的分数小于p1指向的学生的分数
        max->num = p1->num;    
        max->score = p1->score;
      }                //将max指针重新指向分数更高的学生,并更新max指针所指向的学生的编号和分数。
 cout << max->num << " " << max->score;
 }                                          //最后输出最高分学生的编号和分数。
相关推荐
进击的小头22 分钟前
陷波器实现(针对性滤除特定频率噪声)
c语言·python·算法
知无不研25 分钟前
冒泡排序算法
算法·冒泡排序·排序
毅炼27 分钟前
hot100打卡——day17
java·数据结构·算法·leetcode·深度优先
Tisfy30 分钟前
LeetCode 3010.将数组分成最小总代价的子数组 I:排序 OR 维护最小次小
算法·leetcode·题解·排序·最小次小值
Trouvaille ~33 分钟前
【Linux】线程同步与互斥(三):生产者消费者模型实战
linux·运维·c++·信号量·阻塞队列·生产者消费者模型·环形队列
Learn Beyond Limits34 分钟前
文献阅读:A Probabilistic U-Net for Segmentation of Ambiguous Images
论文阅读·人工智能·深度学习·算法·机器学习·计算机视觉·ai
Queenie_Charlie38 分钟前
八皇后问题
c++·深度优先搜索
m0_736919101 小时前
编译器命令选项优化
开发语言·c++·算法
Jiu-yuan1 小时前
C++函数
c++
naruto_lnq1 小时前
C++中的工厂方法模式
开发语言·c++·算法