0903作业+思维导图

news2024/11/13 10:21:19

一、作业

1》多态的实现

1、代码

#include <iostream>

using namespace std;
//父类
class Person
{
public:
    string name;
    int age;
public:
    Person(){}
    Person(string n,int a):name(n),age(a){}
    ~Person(){}

    //纯虚函数
    virtual void show() = 0;
};
//子类1
class Stu:public Person
{
private:
    int score;    //成绩
    int ranking;  //排名
public:
    Stu(){}
    Stu(int s,int r,string n,int a):Person(n,a),score(s),ranking(r){}
    ~Stu(){}

    void show()
    {
        cout<<name<<":年龄:"<<age<<",成绩"<<score<<",总排名"<<ranking<<endl;
    }
};
//子类2
class Teacher:public Person
{
private:
    int num;    //所带班级人数
    int wages;  //薪资
public:
    Teacher(){}
    Teacher(int num,int w,string n,int a):Person(n,a),num(num),wages(w){}
    ~Teacher(){}

    void show()
    {
        cout<<name<<":年龄:"<<age<<",薪资"<<wages<<",所带班级总人数"<<num<<endl;
    }
};
//全局函数
void fun(Person &s)
{
    s.show();
}
int main()
{
    Stu s1(90,7,"zhangsan",16);
    Teacher t1(41,5600,"xiaoming",35);
    fun(s1);
    fun(t1);
    return 0;
}

2、运行截图

2》自己封装栈和队列

1、栈的实现代码

#include <iostream>

using namespace std;
//栈类
class Stack
{
private:
    int *ptr; //数据指针
    int top;  //栈顶元素数
    int max;
public:
    Stack():top(-1),max(20){
        ptr = new int[max];   //申请空间
        cout<<"无参构造"<<endl;}
    ~Stack(){
        delete ptr;           //释放空间
        cout<<"析构函数"<<endl;}
    Stack(Stack &s):ptr(new int(*s.ptr)),top(s.top),max(s.max)
    {
        cout<<"拷贝构造函数"<<endl;
    }
    //写入初始栈内容
    void operator=(int a)
    {
        //判满
        if(a>max)
        {
            cout<<"error"<<endl;
            return;
        }
        //写入内容
        for(int i=0;i<a;i++)
        {
            cout<<"请输入第"<<i+1<<"位数为:";
            cin>>ptr[i];
            top++;
        }
    }
    //栈顶元素访问
    int stack_top()
    {
        return ptr[top];
    }
    //判空
    bool empty()
    {
        return top==-1;
    }
    //元素数
    int size()
    {
        return top+1;
    }
    //向栈顶插入元素
    void push(int n)
    {
        //判满
        if(top==max-1)
        {
            cout<<"无法继续插入"<<endl;
            return;
        }
        ++this->top;
        this->ptr[top] = n;
    }
    //删除栈顶元素
    void pop()
    {
        //判空
        if(empty())
        {
            return;
        }
        this->top--;
    }
    void show()
    {
        for(int i=0;i<top+1;i++)
        {
            cout<<ptr[i]<<"    ";
        }
        cout<<endl;
    }
};

int main()
{
    Stack s1;   //实例化一个自定义的栈类
    s1.operator=(5);//初始化
    cout<<s1.stack_top()<<endl;
    cout<<s1.size()<<endl;
    s1.push(7);    //入栈
    s1.show();
    s1.pop();      //出栈
    s1.show();
    cout<<"***************"<<endl;
    Stack s2=s1;
    s2.show();
    return 0;
}

2、栈的运行结果

3、队列的实现代码

#include <iostream>

using namespace std;
//队列类
class Queue
{
private:
    int size;      //队列最大容量
    int num;      //队列内元素数
    int *ptr;     //容器
public:
    Queue():size(20),num(0){
        ptr = new int[this->size];
        cout<<"无参构造"<<endl;
    }
    ~Queue(){
        delete ptr;           //释放空间
        cout<<"析构函数"<<endl;
    }
   Queue(Queue &q):size(q.size),num(q.num),ptr(new int(*q.ptr))    //深拷贝
   {
       cout<<"拷贝构造函数"<<endl;
   }
   int front()
   {
       if(empty())
       {
           cout<<"队列为空无法返回"<<endl;
           return -1;
       }
       return ptr[0];
   }
   int back()
   {
       if(empty())
       {
           cout<<"队列为空无法返回"<<endl;
           return -1;
       }
       return ptr[num-1];
   }
   bool empty()
   {
       return num==0;
   }
   int queue_size()
   {
       return num;
   }
   void push(int n)
   {
       //判满
       if(num>=size)
       {
           cout<<"容器已满无法继续加入"<<endl;
           return;
       }
       this->num++;
       this->ptr[num-1] = n;
       cout<<"添加完毕"<<endl;
   }
   void pop()
   {
       //判空
       if(empty())
       {
           cout<<"容器为空无法删除"<<endl;
           return;
       }
       for(int i=0;i<this->num;i++)
       {
           this->ptr[i]=this->ptr[i+1];
       }
       this->num--;
       cout<<"删除完毕"<<endl;
   }
   void show()
   {
       for(int i=0;i<num;i++)
       {
           cout<<ptr[i]<<"  ";
       }
       cout<<endl;
   }
};

int main()
{
    Queue q1;
    q1.push(1);
    q1.push(2);
    q1.push(3);
    q1.show();
    q1.pop();
    q1.show();
    cout<<q1.front()<<"  "<<q1.back()<<endl;
    Queue q2=q1;
    q2.show();
    return 0;
}

4、队列的实现结果

二、思维导图(继承,多态)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2102271.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

游戏开发者必看:Perforce龙智即将携手亮相2024 Unreal Fest上海站,打造游戏开发版本控制新生态

2024年9月5- 6日&#xff08;周四-周五&#xff09;&#xff0c;Unreal Fest Shanghai 2024将在上海宝华万豪酒店隆重举行&#xff01;作为游戏行业备受瞩目的盛会之一&#xff0c;Unreal Fest每年都会吸引来自世界各地的技术专家和行业领导者齐聚一堂&#xff0c;分享最新的技…

『功能项目』销毁怪物蛋的Shaders消融特效【17】

本章项目成果展示 我们打开上一篇16主角的信息显示的项目&#xff0c; 本章要做的事情是在怪物消亡时生成一个销毁特效 首先创建一个Unlit Shader 重命名为Dissolve 双击进入脚本后编写脚本&#xff1a; Shader "Unlit/Dissolve"{Properties{//物体基础材质纹理[Hea…

Apache Kafka UI :一款功能丰富且美观的 Kafka 开源管理平台!!【送源码】

Apache Kafka UI 是一个免费的开源 Web UI&#xff0c;用于监控和管理 Apache Kafka 集群&#xff0c;可方便地查看 Kafka Brokers、Topics、消息、Consumer 等情况&#xff0c;支持多集群管理、性能监控、访问控制等功能。 1 特征 多集群管理&#xff1a; 在一个地方监控和管理…

软考高级网络规划设计师含金量高吗?

网络规划设计师含金量很高&#xff01;这个证书是计算机技术与软件领域的高级专业证书。 拿到这个证书的人&#xff0c;那在网络系统建设方面可是全能选手&#xff0c;从需求分析到规划设计&#xff0c;再到部署实施、评测运维&#xff0c;统统都能搞定。 他们得对网络技术应…

Flutter 小技巧之 Row/Column 即将支持 Flex.spacing

事实上这是一个相当久远的话题&#xff0c;如果对于前因后果不管兴趣&#xff0c;直接看最后就行。 这个需求最早提及应该是 2018 年初在 #16957 被人提起&#xff0c;因为在 Flutter 上 Wrap 有 runSpacing 和 spacing 用于配置垂直和水平间距&#xff0c;而为什么 Colum 和 …

单细胞组学大模型(3)--- scGPT,有非常详细的学习文档和应用说明,且有多种训练数据权重!

–https://doi.org/10.1038/s41592-024-02201-0 代码来源&#xff1a;https://github.com/bowang-lab/scGPT 学习参考&#xff1a;https://scgpt.readthedocs.io/en/latest/introduction.html scGPT: Towards Building a Foundation Model for Single-Cell Multi-omics Usin…

2024.9.3

#include <iostream> #include <cstring> using namespace std;class Stack { private:int len;int count 0;int *stack; public:Stack():len(10) //无参构造{stack new int[len];stack[len] {0};}Stack(int len):len(len) //有参构造{stac…

一文搞懂微服务架构之限流

前置知识 限流是通过限制住流量大小来保护系统&#xff0c;能够解决异常突发流量打崩系统的问题。例如常见的某个攻击者在攻击你维护的系统&#xff0c;那么限流就是极大程度上保护住你的系统。 算法 限流算法也可以像负载均衡算法那样&#xff0c;划分成静态算法和动态算法…

【软件测试专栏】测试分类篇

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;软件测试专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 测试分类篇 关键词&#xff1a;测试方法的概念、测试类型、先后顺…

花生壳二级域名的绑定测试

1、花生壳客户端的登录 左下角显示的就是你的外部IP。 2、新建映射 点击新建映射&#xff0c;就会进入一个管理页面&#xff0c;如下图&#xff1a; 3、可以通过域名访问网站了 就可以二级域名直接访问&#xff0c;在192.168.1.11:8080 上建立的Tomcat网站了&#xff0c;非常…

uniapp写的一个年月日时分秒时间选择功能

代码: <template><view><picker mode"multiSelector" :value"multiIndex" :range"multiRange" change"onMultiChange"><view class"picker">当前选择&#xff1a;{{ formattedDateTime }}</vie…

各业务领域相关方案

电商 电商系统的简单架构 电商系统的简单架构_电商交易平台 系统架构-CSDN博客 订单系统 美团团购订单系统优化记 vivo 全球商城&#xff1a;订单中心架构设计与实践 库存系统 电商库存系统的防超卖和高并发扣减方案 vivo全球商城&#xff1a;库存系统架构设计与实践 资金…

开篇_____何谓安卓机型“工程固件” 与其他固件的区别 作用

此系列博文将分析安卓系列机型与一些车机 wifi板子等工程固件的一些常识。从早期安卓1.0起始到目前的安卓15&#xff0c;一些厂家发布新机型的常规流程都是从工程机到量产的过程。在其中就需要调试各种参数以便后续的量产参数可以固定到最佳&#xff0c;工程固件由此诞生。 后…

30道python自动化测试面试题与答案汇总

对于机器学习算法工程师而言,Python是不可或缺的语言,它的优美与简洁令人无法自拔,下面这篇文章主要给大家介绍了关于30道python自动化测试面试题与答案汇总的相关资料,需要的朋友可以参考下 1、什么项目适合做自动化测试&#xff1f; 关键字&#xff1a;不变的、重复的、规范…

【Agent】Agent Q: Advanced Reasoning and Learning for Autonomous AI Agents

1、问题背景 传统的训练Agent方法是在静态数据集上进行监督预训练&#xff0c;这种方式对于要求Agent能够自主的在动态环境中可进行复杂决策的能力存在不足。例如&#xff0c;要求Agent在web导航等动态设置中执行复杂决策。 现有的方式是用高质量数据进行微调来增强Agent在动…

专业文件搜索工具 | UltraSearch Pro v4.4.1.1015 绿色特别版

大家好&#xff0c;今天电脑天空给大家推荐一款非常实用的文件搜索软件——UltraSearch Pro。这款软件在文件搜索领域有着出色的表现。 UltraSearch Pro 是一款专业的文件搜索工具&#xff0c;以其快速、全面、精准的搜索能力赢得了用户的一致好评。无论是本地硬盘、网络驱动器…

【IPV6从入门到起飞】2-2 获取你的IPV6(Teredo隧道)

【IPV6从入门到起飞】2-2 获取你的IPV6&#xff08;Teredo隧道&#xff09; 1 打工人的忧伤2 Teredo介绍2.1 背景2.2 工作原理 3 Linux 服务器获取IPV63.1 安装3.2 设置开机自启动和启动3.3 开放防火墙 UDP 35443.4 查看IPV6以及ping包测试3.5 修改Teredo服务器3.6 重启服务3.7…

系统思考—关键决策

结‮影构‬响行为&#xff0c;精‮决准‬策创造价值&#xff01; 最‮身近‬边很多‮伙小‬伴找我“助力”&#xff0c;父‮也母‬经常发‮息信‬让我帮忙&#xff0c;忍‮住不‬研究了一下‮些这‬助力活动的“玩法”。说实话&#xff0c;这‮设种‬计从‮构结‬上真‮很的‬…

论文精读:Dirac半金属反常能斯特效应设计

摘要节选&#xff1a; 反常能思特效应&#xff08;ANE&#xff09;产生垂直于温度梯度的横向电压。与用于能量转换的纵向热电相比&#xff0c;它具有电子和热输运解耦、更高的灵活性和更简单的横向结构等优点。 在这项工作中&#xff0c;从理论上证明了一对Dirac节点在Zeeman…

用Leangoo领歌敏捷工具进行迭代管理的实践分享Sprint Backlog

在敏捷开发中&#xff0c;迭代管理是确保项目持续推进、不断优化的重要环节。有效的迭代管理能够帮助团队快速响应变化&#xff0c;持续交付高质量产品。 Leangoo是一款免费的敏捷项目管理工具&#xff0c;为团队提供了直观、高效的看板管理方式来管理迭代过程。本文将探讨如何…