c++上机实验四:继承与派生

实验目的和要求

  1. 理解类的继承的概念,能够定义和使用类的继承关系。
  2. 掌握派生类的声明与定义方法。
  3. 熟悉够有派生和私有派生的访问特性。
  4. 掌握虚基类在解决二义性问题中的作用。

实验内容:

  1. 定义一个存放一组整数的基类。
  2. 定义三个派生类,其中的成员函数分别实现排序、逆转、求解平均值的功能。
  3. 定义一个新的派生类,同时继承以上的三个派生类,继承过程使用虚基类。

代码

#include <iostream>
using namespace std;
class Myarray
{
protected:
    int *alist;		//指向动态申请的一组空间
    int length;		//整数的个数
public:
    Myarray(int len)	//初始化,动态申请存储空间
    {
        alist=new int[len];
        length=len;
        cout<<"Myarray 初始化..."<<endl;
    }
    ~Myarray()			//对象结束时,释放所占用的存储空间
    {
        delete(alist);
        cout<<endl<<"再见!"<<endl;
    }
    void Input()		//输入数据
    {
        int i;
        for(i=0; i<length; i++)
        {
            cout<<"输入数组的第"<<i+1<<"个元素:";
            cin>>alist[i];
        }
    }
    void Display()		//显示数据
    {
        cout<<endl<<"本数组成员依次为:";
        for(int i=0; i<length; i++)
            cout<<alist[i]<<' ';
        cout<<endl;
    }
};

class SortArray:virtual public Myarray	//从小到大排序
{
public:
    SortArray(int n):Myarray(n)
    {
        cout<<"SortArray 初始化..."<<endl;
    }
    void get_SortArray()
    {
        int i,j,k,temp;
        for(i=0; i<length-1; i++)
        {
            k=i;
            for(j=i+1; j<length; j++)
                if(alist[j]<alist[k])
                {
                    k=j;
                }
            temp=alist[i];
            alist[i]=alist[k];
            alist[k]=temp;
        }
    }
};

class ReArray: virtual public Myarray	//前后逆转
{
public:
    ReArray(int n):Myarray(n)
    {
        cout<<"ReArray 初始化..."<<endl;
    }
    void get_ReArray()
    {
        int i,t,j=length-1;
        for(i=0; i<length/2; i++,j--)
        {
            t=alist[i];
            alist[i]=alist[j];
            alist[j]=t;
        }
    }
};

class AverArray:virtual public Myarray	//求平均值
{
public:
    AverArray(int n):Myarray(n)
    {
        cout<<"AverArray 初始化..."<<endl;
    }
    float get_AverArray()
    {
        float aver;
        int sum=0,i;
        for(i=0; i<length; i++)
            sum+=alist[i];
        aver=(float)sum/length;
        return aver;
    }
};

class NewArray:public SortArray,public ReArray,public AverArray
{
public:
    NewArray(int n):SortArray(n),ReArray(n),AverArray(n),Myarray(n)
    {
        cout<<"NewArray 初始化..."<<endl;
    }
    void fun()
    {
        cout<<endl<<"数组成员的平均值为:";
        cout<<AverArray::get_AverArray()<<' '<<endl;

        cout<<endl<<"现在将数组成员进行前后逆转:"<<endl;
        ReArray::get_ReArray();
        Myarray::Display();

        cout<<endl<<"现在将数组成员进行从小到大排序:"<<endl;
        SortArray::get_SortArray();
        Myarray::Display();
    }
};

int main()
{
    NewArray B(3);
    B.Input();
    B.Display();
    B.fun();
}
  • 9
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

烟敛寒林o

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值