问题 问答题

请使用VC6或使用[答题]菜单打开考生文件夹proj2下的工程proj2。该工程中包含一个程序文件maln.cpp,其中有“书”类Book及其派生出的“教材”类TeachingMaterial的定义,还有主函数main的定义。请在程序中“//********found********”下的横线处填写适当的代码,然后删除横线,以实现上述类定义和函数定义。此程序的正确输出结果应为:
教材名:C++语言程序设计
页 数:299
作 者:张三
相关课程:面向对象的程序设计
注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“//****found****”。
#include <iostream>
using namespace std;
class Book //"书"类
char * title; //书名
int num_pages; //页数
char * writer; //作者姓名
public:
Book(const char * the_title,intpages,const char * the_writer):num_pages(pages)
title=new char[strlen(the_title)+1];
strcpy(title,the_title);
//**********found**********
______
strcpy(writer,the_writer);

~Book()______
int numOfPages()constreturn num_pages; //返回书的页数
const char * theTitle () const return title; //返回书名
const char * theWriter () const return writer; //返回作者名
;
class TeachingMaterial:public Book
//“教材”类
char * course;
public:
TeachingMaterial (const char * the_title,int pages,const char*thewriter,const char * the course)
:______
course=new char[strlen(the_course)+1];
strcpy(course,the_course);

~TeachingMaterial()delete[]course;

const char*theCourse()constreturn course;) //返回相关课程的名称
);
int main()
TeachingMaterial abook ("C++语言程序设计",299,"张三","面向对象的程序设计");
cout<<"教材名:"<<a book.theTitle()<<endl
<<"页 数:"<<a_book.numOfPages()<<endl
<<"作 者:"<<a book.theWriter()<<endl
//**********found**********<<"相关课程:"<<______;
cout<<endl;
return 0;

答案

参考答案:

(A)writer=new char[strlen(the_writer)+A];

(B)delete[]title,writer;

(C)Book(the_title,pages,the_writer)

(D)a_book.theCourse()<<endl

解析:

主要考查Book类及其派生类TeachingMaterial,其中涉及动态数组、构造函数、析构函数、成员函数和成员函数调用。如果要使用指针,那么在构造函数中就会使用new分配空间,在析构函数中使用delete来释放空间。派生类的构造函数必须使用成员列表初始化法先对基类进行初始化。

(1)主要考查考生对动态分配空间的掌握,在填空前可以参考title的初始化,即先分配空间,再使用strcpy函数复制字符串,因此这里使用Writer=new char[strlen(the_writer)+1]语句给writer分配空间,注意分配空间的大小应为字符串长度加1。

(2)主要考查考生对析构函数的掌握,要填写的内容是析构函数的函数体,因为有两个动态数组title和writer,所以要释放两个动态数组空间,使用语句~Book(){delete[]title,writer;}来完成。

(3)主要考查考生对派生类的构造函数的掌握,派生类必须使用成员初始化列表法来先给基类进行初始化。

(4)主要考查成员函数调用,题目要求输出“相关课程:面向对象的程序设计”。可以知道这里要显示的是course,但course是私有成员不能直接调用,要使用成员函数调用,即theCourse()。

问答题

【程序说明】
定义一个多边形结构:struct polygon实现以下内容:(1)建立该结构的链表:create函数是创建链表,每输入一个结点的数据,就把该结点加入到链表当中,它返回创建的链表的头指针。(2)显示链表的各个结点数据:结点数据包括:多边形顶点数、各顶点的纵横坐标、当多边形顶点数为0时,链表创建结束。(3)编写一个函数disp,删除链表中的所有结点。需要注意的是:要先释放结点数据内存,再删除结点,如果在释放结点数据内存单元之前删除结点,则无法找到结点数据内存单元的地址,也就无法释放数据的内存单元。
【程序】
#include "iostxeam. h"
#include "iomanip. h"
stmct polygon

int n;
int *x;
int *y;
polygon *next;
;
void Push(polygon*& head, int n)

polygon* newNode = new polygon;
newNode = new polygon;
newNode->next= (1) ;
newNode->x = new int[n];
newNode->y = new int[n];
newNode->n= (2) ;
for(int i=0; i<= (3) ; i++)
cout<<"请输入多边形各顶点x、y坐标, 坐标值之间用空格分隔: ";
cin>>newNode->x[i]>>newNode->y[i];

(4) = head; //在head前不需要额外的*
head = newNode;

polygon *create()

polygon* head = NULL;
polygon* tail;
int n;
cout<<"请输入多边形顶点的个数(顶点个数为0时结束): ";
cin>>n;
if(n==O) return (5) ;
Push(head, (6) );
tail = head;
cout<<"请输入多边形顶点的个数(顶点个数为0时结束): ";
cin>>n;
while(n!=0)

Push(tail->next, (7) ); // 在tail->next增加结点
tail = tail->next; //advance tail to point to last node
cout<<"请输入多边形顶点的个数(顶点个数为0时结束): ";
cin>>n;

remm head;

void disp(polygon *head)

inti, No=l;
eout<<setw( 10)<<"x"<<setw(6)<<"y"<<endl;
while(head !=NULL)

cout<<"第"<<No<<"结点: "<<endl;
for(i=0;i<=head->n-1;i++)
cout<<setw(10)<<head->x [i] <<setw(6)<<head->y[i]<<endl;
(8) ;
he ad= (9) ;
//Match while statement

void del(polygon *head)

polygon *p;
while(head!=NIILL

p= (10) ;
head=head->next;
delete p->x;
delete p->y;
delete p;
//Match while statement
void main()

polygon *head;
head=create();
disp(head);
del(head);

选择题