第十三周实验报告四

  1. * 程序的版权和版本声明部分 
  2. * Copyright (c) 2011, 烟台大学计算机学院学生 
  3. * All rights reserved. 
  4. * 文件名称: 
  5. * 作者:李君凯 
  6. * 完成日期: 2012年 5月 18日
  7. * 版本号: 
  8. *对任务及求解方法的描述部分
  9. <span style="font-size:16px;">#include<iostream>   
    using namespace std;  
      
    const double PI = 3.14159;  
      
    class CSolid  
    {  
    public:  
        virtual double area() const =0;  
        virtual double volume() const =0;  
    };  
      
    class CCube: public CSolid  
    {  
    public:  
        CCube(double length);  
        virtual double area() const;  
        virtual double volume() const;  
        void show_area();  
        void show_volume();  
    protected:  
        double length;  
    };  
      
    class CBall: public CSolid  
    {  
    public:  
        CBall(double radius);  
        virtual double area() const;  
        virtual double volume() const;  
    protected:  
        double radius;  
    };  
      
    class CCylinder: public CSolid  
    {  
    public:  
        CCylinder(double height, double radius);  
        virtual double area() const;  
        virtual double volume() const;  
        void show_area();  
        void show_volume();  
    protected:  
        double height;  
        double radius;  
    };  
      
    CCube::CCube(double length)  
    {  
        this->length = length;  
    }  
      
    double CCube::area() const  
    {  
        return (this->length * this->length * 6);  
    }  
      
    double CCube::volume() const  
    {  
        return (this->length * this->length * this->length);  
    }  
      
      
    CBall::CBall(double radius)  
    {  
        this->radius = radius;  
    }  
      
    double CBall::area() const  
    {  
        return (4 * PI * this->radius * this->radius);  
    }  
      
    double CBall::volume() const  
    {  
        return (PI * this->radius * this->radius * this->radius * 3 / 4);  
    }  
      
    CCylinder::CCylinder(double height, double radius)  
    {  
        this->height = height;  
        this->radius = radius;  
    }  
      
    double CCylinder::area() const  
    {  
        return (2 * (PI * this->radius * this->radius) + this->height * (2 * PI * this->radius));  
    }  
      
    double CCylinder::volume() const  
    {  
        return (PI * this->radius * this->radius * this->height);  
    }  
      
    int main()  
    {  
        CSolid *p;  
      
        CCube ccube(5);  
        CBall cball(4);  
        CCylinder ccylinder(10, 2);  
      
        p = &ccube;  
      
        cout << "正方体的表面积是:" << p->area() << endl;  
        cout << "正方体的体积是:" << p->volume() << endl;  
      
        p = &cball;  
      
        cout << "球体的表面积是:" << p->area() << endl;  
        cout << "球体的体积是:" << p->volume() << endl;  
      
        p = &ccylinder;  
      
        cout << "圆柱体的表面积是:" << p->area() << endl;  
        cout << "圆柱体的体积是:" << p->volume() << endl;  
      
        system("pause");  
        return 0;  
    }  
    </span>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值