问答题

试题六(15 分,每空3 分) 阅读以下说明和C++程序,将应填入(n) 处的字句写在答题纸的对应栏内。 【说明】 以下程序的功能是计算三角形、矩形和正方形的面积并输出。 程序由4 个类组成:类Triangle、Rectangle 和Square 分别表示三角形、矩形和正方形;抽象类Figure 提供了一个纯虚拟函数getArea(),作为计算上述三种图形面积的通用接口。 【C++程序】 #include #include class Figure { public: virtual double getArea() = 0; // 纯虚拟函数 }; class Rectangle : (1) { protected: double height; double width; public: Rectangle(){}; Rectangle(double height, double width) { this->height = height; this->width = width; } double getArea() { return (2) ; } }; class Square : (3) { public: Square(double width){ (4) ; } }; class Triangle : (5) { double la; double lb; double lc; public: Triangle(double la, double lb, double lc) { this->la = la; this->lb = lb; this->lc = lc; } double getArea() { double s = (la+lb+lc)/2.0; return sqrt(s*(s-la)*(s-lb)*(s-lc)); } }; void main() { Figure* figures[3] = { new Triangle(2,3,3), new Rectangle(5,8), new Square(5) }; for (int i = 0; i < 3; i++) { cout << "figures[" << i << "] area = " << (figures[i])->getArea() << endl; } }

【参考答案】

(1)public Figure(2)height*width(3)public Rectangle(4)height=......

(↓↓↓ 点击下方‘点击查看答案’看完整答案 ↓↓↓)
热门 试题

问答题
试题四(15 分,每空3 分)阅读以下说明和C 代码,将应填入 (n) 处的字句写在答题纸的对应栏内。【说明】某单位举办了一场知识竞赛,参加竞赛的选手为300 名,依次从1~300 进行编号。竞赛时间为9:00~11:00。8 道竞赛题目依次从‘A’~‘H’编号,选手可按任意次序答题,每完成一道题目,可立即提交答案。若答案正确(Y),则选择其他题目进行解答,否则,可继续做该题目或选择其他题目进行解答,直至竞赛结束。选手提交答案的情况及判定结果由专人即时录入,录入的数据如下表1 所示,对竞赛情况进行统计和排名的结果如表2 所示。统计和排名的规则如下:1.若选手X 在竞赛时提交的题目P 解答正确,则解答该题目所用时间如下计算:解答题目P 的用时=提交题目P 正确的时间 - 竞赛的开始时间+罚时罚时=提交题目P 错误解答的次数×20例如:表1 中14 号选手在10:27 提交了题目A 的正确解答,因此该选手正确解答该题目所用时间为87 分钟,由于之前的两次提交错误解答,罚时为2×20=40 分钟,所以14 号选手解答题目A 的用时=87+40=127(分钟)。2.已经提交正确答案的题目再次提交时不再计算。3.竞赛结束时,选手的总用时为所有解答正确的题目用时累加所得,解答不正确的题目不计时。4.排名时,完成题目数量多者排名靠前;若完成的题目数相同,则用时少者排名靠前;若完成的题目数和所用时间均相等,则名次相同;完成题目数为0 的选手不参加排名。函数void Statistic() 的功能是:读取输入数据,进行统计、排名并输出结果。#define MAXN 300typedef struct {int no; *选手编号* int num; *完成的题目数量* int time; *完成题目的总用时* int d[8]; *d[i]用于记录提交第i 个题目错误答案的次数* int a[8]; *a[i]用于记录第i 个题目是否已经提交正确答案* }Info;【函数】void Statistic() {char ch,pass;int i,j,k,h,m,t,time,MaxIndex;Info R[MAXN+1];for(i=1; i MaxIndex) MaxIndex = k;} *while* for(i=1; i 0) {if (R[i].num!=R[0].num || R[i].time!=R[0].time) k++;R[0] = (5) ;printf( %d: %3d %4d %5d n ,k,R[i].no,R[i].num,R[i].time);} *if* } *Statistic*