《C++语言基础》实践参考——指向学生类的指针

简介: 返回:贺老师课程教学链接【项目4-指向学生类的指针】设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set、get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索)。在main函数中,要做到:建立一个对象数组,通过初始化,设置5个学生的数据,要求:用指针指向数组首元素,输出第1、3、5个学生的信

返回:贺老师课程教学链接


【项目4-指向学生类的指针】

设计一个学生类Student,数据成员包括学号(num)和成绩(score),成员函数根据需要自行设计(建议配备需要的set、get函数,以及必要的输入或输出,给出的代码中也可以找到需要成员函数的线索)。在main函数中,要做到:
  • 建立一个对象数组,通过初始化,设置5个学生的数据,要求:
  • 用指针指向数组首元素,输出第1、3、5个学生的信息;
  • 设计一个函数int max(Student *arr);,用指向对象的指针作函数参数,在max函数中找出5个学生中成绩最高者,并返回值其学号。
下面给出部分程序,在此基础上完成项目:
class Student
{
public:
    ……
private:
    int num;   //学号
    double 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个学生的信息(用循环语句)
    ……
    //输出成绩最高者的学号
    cout<<"5个学生中成绩最高者的学号为: "<<max(stud);//调用函数显示最高成绩
    return 0;
}


//定义函数max,返回arr指向的对象数组中的最高成绩,返回值为最高成绩者的学号
int max(Student *arr)
{
//求最高成绩及对应同学的学号


//返回最高成绩者的学号   

}


[参考解答]
#include <iostream>
using namespace std;

class Student
{
public:
    Student(int n,double s):num(n),score(s) {}
    void display();
    int getNum()
    {
        return num;
    }
    double getScore()
    {
        return score;
    }
private:
    int num;   //学号
    double score;   //成绩
};

void Student::display()
{
    cout<<num<<" "<<score<<endl;
}

//max函数返回arr指向的对象数组中的最高成绩者的学号
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+=2)
    {
        cout<<"学生"<<i+1<<": ";
        stud[i].display();
    }
    //找出个学生中成绩最高者,并输出其学号
    cout<<"5个学生中成绩最高者的学号为: "<<max(stud);//调用函数显示最高成绩
    return 0;
}

//定义函数max,返回arr指向的对象数组中的最高成绩者的学号
int max(Student *arr)
{
    double max_score=arr[0].getScore();//通过公共的成员函数取出私立有的数据成员,用好此法
    int k=0;
    for(int i=1; i<5; i++)
        if(arr[i].getScore()>max_score)
        {
            max_score=arr[i].getScore();
            k=i;
        }
    return arr[k].getNum();
}

  有同学提出,要是最高成绩者不止一位该如何去做?上面的解法,是在没有相同成绩的前提下做的,确实不够实际。

  下面的解法,将max函数定义为,返回最高成绩,而在main函数中将多位同学的学号输出。

#include <iostream>
#include <cmath>
using namespace std;

class Student
{
public:
    Student(int n,double s):num(n),score(s) {}
    void display();
    int getNum()
    {
        return num;
    }
    double getScore()
    {
        return score;
    }
private:
    int num;   //学号
    double score;   //成绩
};

void Student::display()
{
    cout<<num<<" "<<score<<endl;
}

//max函数返回arr指向的对象数组中的最高成绩
double 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,100)
    };

    //输出第1、3、5个学生的信息
    for(int i=0; i<5; i+=2)
    {
        cout<<"学生"<<i+1<<": ";
        stud[i].display();
    }
    //找出个学生中成绩最高者,并输出其学号
    double max_score = max(stud); //调用函数求最高成绩
    cout<<"5个学生中成绩最高者的学号为: ";
    for(int i=0; i<5; i++)
    {
        if(abs(stud[i].getScore() - max_score)<1e-7)  //浮点数不能直接比较相等,只要相减小于一个很小的值,就认为相等
            cout<<stud[i].getNum()<<"  ";
    }
    cout<<endl;
    return 0;
}

//定义函数max,返回arr指向的对象数组中的最高成绩
double max(Student *arr)
{
    double max_score=arr[0].getScore();//通过公共的成员函数取出私立有的数据成员,用好此法
    for(int i=1; i<5; i++)
        if(arr[i].getScore()>max_score)
        {
            max_score=arr[i].getScore();
        }
    return max_score;
}


#include <iostream>
using namespace std;

class Student
{
public:
    Student(int n,double s):num(n),score(s) {}
    void display();
    int getNum()
    {
        return num;
    }
    double getScore()
    {
        return score;
    }
private:
    int num;   //学号
    double score;   //成绩
};

void Student::display()
{
    cout<<num<<" "<<score<<endl;
}

//max函数返回arr指向的对象数组中的最高成绩者的学号
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+=2)
    {
        cout<<"学生"<<i+1<<": ";
        stud[i].display();
    }
    //找出个学生中成绩最高者,并输出其学号
    cout<<"5个学生中成绩最高者的学号为: "<<max(stud);//调用函数显示最高成绩
    return 0;
}

//定义函数max,返回arr指向的对象数组中的最高成绩者的学号
int max(Student *arr)
{
    double max_score=arr[0].getScore();//通过公共的成员函数取出私立有的数据成员,用好此法
    int k=0;
    for(int i=1; i<5; i++)
        if(arr[i].getScore()>max_score)
        {
            max_score=arr[i].getScore();
            k=i;
        }
    return arr[k].getNum();
}

  周经纬同学提出,要是最高成绩者不止一位该如何去做?上面的解法,是在没有相同成绩的前提下做的,确实不够实际。

  下面的解法,将max函数定义为,返回最高成绩,而在main函数中将多位同学的学号输出。

#include <iostream>
#include <cmath>
using namespace std;

class Student
{
public:
    Student(int n,double s):num(n),score(s) {}
    void display();
    int getNum()
    {
        return num;
    }
    double getScore()
    {
        return score;
    }
private:
    int num;   //学号
    double score;   //成绩
};

void Student::display()
{
    cout<<num<<" "<<score<<endl;
}

//max函数返回arr指向的对象数组中的最高成绩
double 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,100)
    };

    //输出第1、3、5个学生的信息
    for(int i=0; i<5; i+=2)
    {
        cout<<"学生"<<i+1<<": ";
        stud[i].display();
    }
    //找出个学生中成绩最高者,并输出其学号
    double max_score = max(stud); //调用函数求最高成绩
    cout<<"5个学生中成绩最高者的学号为: ";
    for(int i=0; i<5; i++)
    {
        if(abs(stud[i].getScore() - max_score)<1e-7)  //浮点数不能直接比较相等,只要相减小于一个很小的值,就认为相等
            cout<<stud[i].getNum()<<"  ";
    }
    cout<<endl;
    return 0;
}

//定义函数max,返回arr指向的对象数组中的最高成绩
double max(Student *arr)
{
    double max_score=arr[0].getScore();//通过公共的成员函数取出私立有的数据成员,用好此法
    for(int i=1; i<5; i++)
        if(arr[i].getScore()>max_score)
        {
            max_score=arr[i].getScore();
        }
    return max_score;
}

目录
相关文章
|
23天前
|
缓存 安全 编译器
C++面试周刊(3):面试不慌,这样回答指针与引用,青铜秒变王者
《C++面试冲刺周刊》第三期聚焦指针与引用的区别,从青铜到王者级别面试回答解析,助你21天系统备战,直击高频考点,提升实战能力,轻松应对大厂C++面试。
71 10
C++面试周刊(3):面试不慌,这样回答指针与引用,青铜秒变王者
|
24天前
|
存储 C++
C++语言中指针变量int和取值操作ptr详细说明。
总结起来,在 C++ 中正确理解和运用 int 类型地址及其相关取值、设定等操纵至关重要且基础性强:定义 int 类型 pointer 需加星号;初始化 pointer 需配合 & 取址;读写 pointer 执向之处需配合 * 解引用操纵进行。
135 12
|
4月前
|
监控 算法 数据处理
基于 C++ 的 KD 树算法在监控局域网屏幕中的理论剖析与工程实践研究
本文探讨了KD树在局域网屏幕监控中的应用,通过C++实现其构建与查询功能,显著提升多维数据处理效率。KD树作为一种二叉空间划分结构,适用于屏幕图像特征匹配、异常画面检测及数据压缩传输优化等场景。相比传统方法,基于KD树的方案检索效率提升2-3个数量级,但高维数据退化和动态更新等问题仍需进一步研究。未来可通过融合其他数据结构、引入深度学习及开发增量式更新算法等方式优化性能。
131 17
|
8月前
|
存储 C语言 C++
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
331 77
|
8月前
|
存储 C++
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
【数据结构——树】哈夫曼树(头歌实践教学平台习题)【合集】目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果:任务描述 本关任务:编写一个程序构建哈夫曼树和生成哈夫曼编码。 相关知识 为了完成本关任务,你需要掌握: 1.如何构建哈夫曼树, 2.如何生成哈夫曼编码。 测试说明 平台会对你编写的代码进行测试: 测试输入: 1192677541518462450242195190181174157138124123 (用户分别输入所列单词的频度) 预
187 14
【C++数据结构——树】哈夫曼树(头歌实践教学平台习题) 【合集】
|
8月前
|
存储 C++ 索引
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
【数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】初始化队列、销毁队列、判断队列是否为空、进队列、出队列等。本关任务:编写一个程序实现环形队列的基本运算。(6)出队列序列:yzopq2*(5)依次进队列元素:opq2*(6)出队列序列:bcdef。(2)依次进队列元素:abc。(5)依次进队列元素:def。(2)依次进队列元素:xyz。开始你的任务吧,祝你成功!(4)出队一个元素a。(4)出队一个元素x。
236 13
【C++数据结构——栈与队列】环形队列的基本运算(头歌实践教学平台习题)【合集】
|
8月前
|
算法 C++
【C++数据结构——查找】二叉排序树(头歌实践教学平台习题)【合集】
【数据结构——查找】二叉排序树(头歌实践教学平台习题)【合集】 目录 任务描述 相关知识 测试说明 我的通关代码: 测试结果: 任务描述 本关任务:实现二叉排序树的基本算法。 相关知识 为了完成本关任务,你需要掌握:二叉树的创建、查找和删除算法。具体如下: (1)由关键字序列(4,9,0,1,8,6,3,5,2,7)创建一棵二叉排序树bt并以括号表示法输出。 (2)判断bt是否为一棵二叉排序树。 (3)采用递归方法查找关键字为6的结点,并输出其查找路径。 (4)分别删除bt中关键
204 11
【C++数据结构——查找】二叉排序树(头歌实践教学平台习题)【合集】
|
8月前
|
C++ 芯片
【C++面向对象——类与对象】Computer类(头歌实践教学平台习题)【合集】
声明一个简单的Computer类,含有数据成员芯片(cpu)、内存(ram)、光驱(cdrom)等等,以及两个公有成员函数run、stop。只能在类的内部访问。这是一种数据隐藏的机制,用于保护类的数据不被外部随意修改。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。成员可以在派生类(继承该类的子类)中访问。成员,在类的外部不能直接访问。可以在类的外部直接访问。为了完成本关任务,你需要掌握。
164 19
|
8月前
|
存储 编译器 数据安全/隐私保护
【C++面向对象——类与对象】CPU类(头歌实践教学平台习题)【合集】
声明一个CPU类,包含等级(rank)、频率(frequency)、电压(voltage)等属性,以及两个公有成员函数run、stop。根据提示,在右侧编辑器补充代码,平台会对你编写的代码进行测试。​ 相关知识 类的声明和使用。 类的声明和对象的声明。 构造函数和析构函数的执行。 一、类的声明和使用 1.类的声明基础 在C++中,类是创建对象的蓝图。类的声明定义了类的成员,包括数据成员(变量)和成员函数(方法)。一个简单的类声明示例如下: classMyClass{ public: int
202 13
|
8月前
|
Java C++
【C++数据结构——树】二叉树的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现二叉树的基本运算。​ 相关知识 创建二叉树 销毁二叉树 查找结点 求二叉树的高度 输出二叉树 //二叉树节点结构体定义 structTreeNode{ intval; TreeNode*left; TreeNode*right; TreeNode(intx):val(x),left(NULL),right(NULL){} }; 创建二叉树 //创建二叉树函数(简单示例,手动构建) TreeNode*create
179 12