/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:刘佳琦
* 完成日期:2015年 3 月 27 日
* 版 本 号:v1.0
*
* 问题描述:设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set、get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索)。在main函数中,要做到:
建立一个对象数组,通过初始化,设置5个学生的数据,要求:
用指针指向数组首元素,输出第1、3、5个学生的信息;
设
* 程序输出:无
*/
#include <iostream>
using namespace std;
class Student
{
public:
Student(int n,double s)
{
num=n;
score=s;
}
int getNum()
{
return num;
}
double getScore()
{
return score;
}
void output()
{
cout<<num<<" "<<score<<endl;
}
private:
int num; //学号
double score; //成绩
};
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)
};
for(int i=0; i<5; i+=2)
{
cout<<"学生"<<i+1<<": ";
stud[i].output();
}
//找出个学生中成绩最高者,并输出其学号
cout<<"5个学生中成绩最高者的学号为: "<<max(stud);//调用函数显示最高成绩
return 0;
}
//定义函数max,返回arr指向的对象数组中的最高成绩者的学号
int max(Student *arr)
{
double max=arr[0].getScore();
int k=0;
for(int i=1; i<5; i++)
if(arr[i].getScore()>max)
{
max=arr[i].getScore();
k=i;
}
return arr[k].getNum();
}
运行结果:
学习心得:
指针的用法还是不熟练,尤其是写到max函数的时候,有些遗忘以及不确定,翻了翻以前的博文,回忆了一些内容,本来是想用冒泡排序的,后面发现自己想复杂了,而且冒泡排序无法找到原来那个最大学号的人,除非再重新定义一个数组,这样就更加麻烦了,对于思维的局限性,我觉得我还需要加强练习,指针应该多熟悉,以前指针的题都喜欢用数组代替= =,导致指针还是不熟练。