zoukankan      html  css  js  c++  java
  • 第13周 【项目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;
    }

    代码:
    #include <iostream>
    #include <cmath>
    #define PI 3.14159
    using namespace std;
    class Shape{
    public:
        virtual double area()=0;
    };
    class Circle:public Shape{
    private:
        double r;
    public:
        Circle(double a=0):r(a){}
        double area(){return r*r*PI;}
    };
    class Rectangle:public Shape{
    private:
        double l,w;
    public:
        Rectangle(double a, double b):l(a),w(b){}
        double area(){return l*w;}
    };
    class Triangle:public Shape{
    private:
        double h,l;
    public:
        Triangle(double a,double b):h(a),l(b){}
        double area(){return h*l/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;
    }
    

    执行结果:
  • 相关阅读:
    Bzoj 1537: [POI2005]Aut- The Bus 题解 [由暴力到正解]
    Bzoj 3126[Usaco2013 Open]Photo 题解
    Bzoj 3165 [Heoi2013]Segment题解
    Bzoj 2733: [HNOI2012]永无乡 数组Splay+启发式合并
    赛前集训前的总结(警醒)
    bzoj3316 JC loves Mkk题解
    9.22考试 crf的军训 题解
    Luogu3521 [POI2011]ROT-Tree Rotations
    CTSC2012 熟悉的文章
    UVA11468 Substring
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5206105.html
Copyright © 2011-2022 走看看