第十三周项目二 形状类族中的纯虚函数
来源:互联网 发布:畅想软件开发有限公司 编辑:程序博客网 时间:2024/05/01 14:17
/* Copyright (c) 2014, 烟台大学计算机学院* All rights reserved.* 文件名称:test.cpp* 作者:刘佳琦* 完成日期:2015年 5 月 31 日* 版 本 号:v1.0** 问题描述:写一个程序,定义抽象基类Shape,由它派生出3个派生类,Circle(圆形)、Rectangle(矩形)、Triangle(三角形)。用如下的main()函数,求出定义的几个几何体的面积和。 * 程序输入:* 程序输出:*/#include<iostream>#include<string>using namespace std;class Shape{public: virtual float area()const { return 0.0; }};class Circle:public Shape{private: float radius;public: Circle(float r):radius(r) {} virtual float area() const { return 3.14159*radius*radius; }};class Rectangle:public Shape{public: Rectangle(float w,float h):width(w),height(h) {} virtual float area() const { return width*height; }protected: float width,height;};class Triangle:public Shape{public: Triangle(float w,float h):width(w),height(h) {} virtual float area() const { return 0.5*width*height; }protected: float width,height;};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;}
运行结果:
学习心得:
通过项目一,已经对虚函数,纯虚函数,抽象类有了进一步认识,通过每个项目的小结,巩固了知识和语法点。
0 0
- 第十三周项目二 形状类族的中的纯虚函数
- 第十三周 项目二:形状类族中的纯虚函数
- 第十三周项目二:形状类族的中的纯虚函数
- 第十三周项目二 形状类族的中的纯虚函数
- 第十三周项目二 形状类族中的纯虚函数
- 15第十三周项目二——形状类族中的纯虚函数
- 第十三周项目二形状类族的中的纯虚函数
- 第十三周 项目二--形状类族中的纯虚函数
- 第十三周项目二:形状类族的中的纯虚函数
- 2015年第十三周项目二:形状类族的中的纯虚函数
- 第十三周 项目二 形状类族的中的纯虚函数
- 第十三周 项目二 形状类族中的纯虚函数
- 第十三周项目二-形状类族中的纯虚函数
- 第十三周项目二 形状类族中的纯虚函数
- 第十三周 课后实践:项目二——形状类族中的纯虚函数
- 第十三周项目二--形状类族中的虚函数
- 第十三周项目二 形状类族中的纯虚数函数
- 第十三周项目2——【项目2-形状类族的中的纯虚函数】
- KnockOut源码精析 一个简单的例子(一)
- 用python多线程抓取网站图片,速度极快
- 个人认为讲解java异常最好的文章
- 屏幕的单位和尺寸
- UVa1600做题总结
- 第十三周项目二 形状类族中的纯虚函数
- WinsockPragramming(1) Server(C++版)
- WinsockPragramming(2) Client(C++版)
- 常量指针和指针常量
- SDN入门实战(二)
- Material新闻项目
- 三角形已知两边一斜角时求第三边的公式
- Project Euler:Problem 20 Factorial digit sum
- 十二周——多态性——有阅读程序(3.2)