• 第十三周项目2-形状类族的中的纯虚函数


    写一个程序,定义抽象基类Shape,由它派生出3个派生类,Circle(圆形)、Rectangle(矩形)、Triangle(三角形)。用如下的main()函数,求出定义的几个几何体的面积和。

    int main()
    {
        Circle c1(12.6),c2(4.9);//建立Circle类对象c1,c2,参数为圆半径
        Rectangle r1(4.5,8.4),r2(5.0,2.5);//建立Rectangle类对象r1,r2,参数为矩形长、宽
        Triangle t1(4.5,8.4),t2(3.4,2.8); //建立Triangle类对象t1,t2,参数为三角形底边长与高
        Shape *pt[6]= {&c1,&c2,&r1,&r2,&t1,&t2}; //定义基类指针数组pt,使它每一个元素指向一个派生类对象
        double areas=0.0; //areas为总面积
        for(int i=0; i<6; i++)
        {
            areas=areas + pt[i]->area();
        }
        cout<<"totol of all areas="<<areas<<endl;   //输出总面积
        return 0;
    }
    

    /*
    * Copyright (c) 2015,烟台大学计算机学院
    * All right reserved.
    * 作者:邵帅
    * 文件:Demo.cpp
    * 完成时间:2015年06月07日
    * 版本号:v1.0
    */
    #include <iostream>
    #include <string>
    using namespace std;
    class Shape
    {
    public:
        virtual double area()=0;
    };
    class Circle:public Shape
    {
    private:
        double radius;
    public:
        Circle(double r):radius(r){}
        virtual double area()
        {
            return (3.14*radius*radius);
        }
    };
    class Rectangle:public Shape
    {
    private:
        double leight;
        double height;
    public:
        Rectangle(double l,double h):leight(l),height(h){}
        virtual double area()
        {
            return (leight*height);
        }
    };
    class Triangle:public Shape
    {
    private:
        double underline;
        double height;
    public:
        Triangle(double u,double h):underline(u),height(h){}
        virtual double area()
        {
            return (underline*height*1/2);
        }
    };
    int main()
    {
        Circle c1(12.6),c2(4.9);//建立Circle类对象c1,c2,参数为圆半径
        Rectangle r1(4.5,8.4),r2(5.0,2.5);//建立Rectangle类对象r1,r2,参数为矩形长、宽
        Triangle t1(4.5,8.4),t2(3.4,2.8); //建立Triangle类对象t1,t2,参数为三角形底边长与高
        Shape *pt[6]= {&c1,&c2,&r1,&r2,&t1,&t2}; //定义基类指针数组pt,使它每一个元素指向一个派生类对象
        double areas=0.0; //areas为总面积
        for(int i=0; i<6; i++)
        {
            areas=areas + pt[i]->area();
        }
        cout<<"totol of all areas="<<areas<<endl;   //输出总面积
        return 0;
    }
    

    运行结果:



    @ Mayuko

  • 相关阅读:
    求多边形的面积
    Sequence operation3397
    Atlantis1542(线段树求矩形覆盖面积)
    hdu3033 分组背包(每组最少选一个)
    poj3468A Simple Problem with Integers(线段树延时更新)
    Picture 1828
    Minimum Inversion Number 1394(线段树法)
    hdu2955 Robberies 01背包
    C# 对MongoDB数据库进行增删该
    C#连接MongoDB数据库应用实战
  • 原文地址:https://www.cnblogs.com/mayuko/p/4567471.html
Copyright © 2020-2023  润新知