12.5 作业

1,

以下是一个简单的比喻,将多态概念与生活中的实际情况相联系:

比喻:动物园的讲解员和动物表演

想象一下你去了一家动物园,看到了许多不同种类的动物,如狮子、大象、猴子等。现在,动物园里有一位讲解员,他会为每种动物表演做简单的介绍。

在这个场景中,我们可以将动物比作是不同的类,而每种动物表演则是类中的函数。而讲解员则是一个基类,他可以根据每种动物的特点和表演,进行相应的介绍。

具体过程如下:

定义一个基类 Animal,其中有一个虛函数perform(),用于在子类中实现不同的表演行为。

cpp 复制代码
#include <iostream>

using namespace std;
class Animal{
private:
    string name;
public:
    Animal(){}
    Animal(string name):name(name)
    {}
    virtual void perform()
    {
        cout << name;
    }
};

class Perference:public Animal
{
private:
    string object;
public:
    Perference(){}
    Perference(string name,string object):Animal(name),object(object)
    {

    }
    void perform(){
        Animal::perform();
        cout << "表演的项目是:" << object << endl;;

    }

};

class Person:public Animal
{
private:
    int id;
public:
    Person(){}
    Person(string name,int id):Animal(name),id(id)
    {
    }
    void perform(){
        cout << id;
        cout << "讲解员正在讲解:" ;
        Animal::perform();
        cout << endl;
    }

};

int main()
{
    Person s("狮子",1001);
    Perference d("海豚","跳水圈");
    Animal *p;
    p=&s;
    p->perform();
    p=&d;
    p->perform();
    return 0;
}

结果:

2,思维导图

相关推荐
To_OC11 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵15 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC17 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
郝学胜_神的一滴1 天前
CMake 30:循环语法全解|foreach_while双循环精讲、迭代技巧与实战避坑指南
c++·cmake
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法