设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set、get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索)。在main函数中,要做到:
- 建立一个对象数组,通过初始化,设置5个学生的数据,要求:
- 用指针指向数组首元素,输出第1、3、5个学生的信息;
- 设计一个函数int max(Student *arr);,用指向对象的指针作函数参数,在max函数中找出5个学生中成绩最高者,并返回值其学号。
<span style="font-size:14px;"><strong>/*
*copyright (c) 2015,
*All rights reserved
*The Author:王争取
*Finished Time:2015.4.4</strong></span><span style="font-size:14px;"><strong>
*/
#include <iostream>
using namespace std;
class Student
{
public:
Student (int a,double b):num(a),score(b){};
double get_score();
double get_num();
void set();
private:
int num; //学号
double score; //成绩
};
double Student::get_score()
{
return score;
}
double Student::get_num()
{
return num;
}
void Student::set()
{
cin>>num>>score;
}
//max函数返回arr指向的对象数组中的最高成绩(max并不是成员函数,而是普通函数)
int max(Student *arr);
int main()
{
Student stud[5]=
{
Student(101,78.5),Student(102,85.5),Student(103,100),
Student(104,98.5),Student(105,95.5)
};
//输出第1、3、5个学生的信息(用循环语句)
for(int i=0; i<5; i++)
{
if(i%2!=0)
cout<<stud[i].get_num()<<" "<<stud[i].get_score()<<endl;
}
//输出成绩最高者的学号
cout<<"5个学生中成绩最高者的学号为: "<<max(stud);//调用函数显示最高成绩
return 0;
}
//定义函数max,返回arr指向的对象数组中的最高成绩,返回值为最高成绩者的学号
int max(Student *arr)
{
double x;
x=arr->get_score();
int i;
//求最高成绩及对应同学的学号
for(i=0; i<5; i++)
{
if((arr+i)->get_score()>x)
x=(arr+i)->get_score();
else break;
}
//返回最高成绩者的学号
return (arr+i)->get_num();</strong></span>
面向对象数组的指针和常规数组的指针用法大同小异,只不过面向对象的指针访问私有数据时需要通过对象的成员函数访问而已。
目前最大的问题就是解题方法的问题,我想应该放开思维会做的更好
学生类与成绩比较

被折叠的 条评论
为什么被折叠?



