1、二级 C+-58及答案解析(总分:100.00,做题时间:90 分钟)一、B基本操作题/B(总题数:1,分数:30.00)1.请使用 VC6或使用答题菜单打开考生文件夹 proj1下的工程 proj1,此工程中含有一个源程序文件proj1.cpp。其中位于每个注释“/ERROR *found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为: Base:Good Luck! Derived:Good Luck! 注意:只修改注释“/ERROR *found*”的下一行语句,不要改动程序中的其他内容。 /praj1.cpp #include iostream #include cst
2、ring using namespace std; class Base / ERROR * found* private: char* msg; public: Base(char* str) / ERROR * found* msg:new charstrlen(str); strcpy (msg, str); cout “Base: “ msg endl; / ERROR * found* Base() delete msg; ; class Derived:public Base public: Derived (char* str):Base(str) void Show () co
3、ut “Derived:“ msg endl; ; int main ( ) Derived obj (“Good Luck! “); obj.Show(); return 0; (分数:30.00)_二、B简单应用题/B(总题数:1,分数:30.00)2.请使用 VC6或使用答题菜单打开考生文件夹 proj2下的工程 proj2,函数 void Insert(node*q)使程序能完成如下功能:从键盘输入一行字符,调用该函数建立反序单链表,再输出整个链表。 注意:请勿修改主函数 main和其他函数中的任何内容,只需在横线处编写适当代码,也不要删除或移动“/*found*”。 /proj2.c
4、pp #include iostream using namespace std; struct node char data; node * link; * head; /链表首指针 void Insert (node * q) /将节点插入链表首部 /* found* _; head = q; int main ( ) char ch; node * p; head = NULL; cout “Please input the string“ endl; while(ch=cin.get() !=/n) /* found* _; /用 new为节点 p动态分配存储空间 p -data =
5、ch; /* found* _; /插入该节点 p=head; while (p!=NULL) cout p - data; p=p-link; cout endl; return 0; (分数:30.00)_三、B综合应用题/B(总题数:1,分数:40.00)3.请使用 VC6或使用答题菜单打开考生文件夹 proj3下的工程 prog3,其中声明了 ValArray类,该类在内部维护一个动态分配的 int型数组 v。ValArray 类的成员函数 cycle用于对数组元素进行向左循环移动。调用一次 cycle后,数组的第二个元素至最后一个元素都将向左移动一个位置,而最左端的元素将循环移动到最
6、右端位置上。例如,若 ValArray表示的数组为1,2,3,4,5,则第一次调用 cycle后,数组变为2,3,4,5,1,第二次调用 cycle后,数组变为3,4,5,1,2,依次类推。请编写成员函数cycle。在 main函数中给出了一组测试数据,此情况下程序的输出应该是: v=1,2,3,4,5 v=2,3,4,5,1 v=3,4,5,1,2 v=4,5,1,2,3 v=5,1,2,3,4 要求: 补充编制的内容写在“/*333*”与“/*666*”之间,不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out.dat中。输出函数 writeToFile已经编译为 obj文件,
7、并且在本程序中调用。 /ValArray.h #include iostream using namespace std; class ValArray int* v; int size; public: ValArray const int* p, int n): size (n) v = new intsize; for (int i = 0; isize; i+) vi = pi; ValArray() delete v; void cycle (); void print(ostream for (int i = 0; i size-1; i+) out vi “,“; out vsi
8、ze-1 ; ; void writeToFile (const char * ); /main. cpp #include “ValArray. h“ void ValArray:cycle () /将数组 v中的 size个整数依次移动到它的前一个单元,其中第一个整数移到原来最后元素所在单元。 /* 333* /* 666* int main ( ) const int a = 1, 2, 3, 4, 5 ; ValArray v(a, 5); for (int i = 0; i 5; i+) cout “v = “; v.print (cout); cout endl; v.cycle(
9、); writeToFile (“); return 0; (分数:40.00)_二级 C+-58答案解析(总分:100.00,做题时间:90 分钟)一、B基本操作题/B(总题数:1,分数:30.00)1.请使用 VC6或使用答题菜单打开考生文件夹 proj1下的工程 proj1,此工程中含有一个源程序文件proj1.cpp。其中位于每个注释“/ERROR *found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为: Base:Good Luck! Derived:Good Luck! 注意:只修改注释“/ERROR *found*”的下一行语句,不要改动程序中的其他内容。 /
10、praj1.cpp #include iostream #include cstring using namespace std; class Base / ERROR * found* private: char* msg; public: Base(char* str) / ERROR * found* msg:new charstrlen(str); strcpy (msg, str); cout “Base: “ msg endl; / ERROR * found* Base() delete msg; ; class Derived:public Base public: Deriv
11、ed (char* str):Base(str) void Show () cout “Derived:“ msg endl; ; int main ( ) Derived obj (“Good Luck! “); obj.Show(); return 0; (分数:30.00)_正确答案:(1)protected: (2)msg=new charstrlen(str)+1; (3)Base()deletemsg;)解析:考点 本题考查 Base类及其派生类 Derived,其中涉及动态数组、构造函数、strcpy()函数和析构函数。 解析 (1)主要考查保护成员,因为在 Base类的派生类中
12、直接调用了 msg,所以这里应该是保护成员。 (2)主要考查考生对动态分配的掌握,由下一条语句:strcpy(msg, str);可知,程序要将字符串 str复制给 msg,因此要给 msg分配空间,空间大小应该为 str的长度加 1。 (3)主要考查考生对析构函数的掌握,delete 语句要加上标识符“”。二、B简单应用题/B(总题数:1,分数:30.00)2.请使用 VC6或使用答题菜单打开考生文件夹 proj2下的工程 proj2,函数 void Insert(node*q)使程序能完成如下功能:从键盘输入一行字符,调用该函数建立反序单链表,再输出整个链表。 注意:请勿修改主函数 mai
13、n和其他函数中的任何内容,只需在横线处编写适当代码,也不要删除或移动“/*found*”。 /proj2.cpp #include iostream using namespace std; struct node char data; node * link; * head; /链表首指针 void Insert (node * q) /将节点插入链表首部 /* found* _; head = q; int main ( ) char ch; node * p; head = NULL; cout “Please input the string“ endl; while(ch=cin.g
14、et() !=/n) /* found* _; /用 new为节点 p动态分配存储空间 p -data = ch; /* found* _; /插入该节点 p=head; while (p!=NULL) cout p - data; p=p-link; cout endl; return 0; (分数:30.00)_正确答案:(1)q-link=head (2)p=new node (3)Insert(p)解析:考点 主要考查的是 Insert函数,其中涉及结构体及链表知识。 解析 (1)主要考查考生对链表的掌握,函数功能是将节点插入链表首部后。在插入链表首部,即将该节点的指针域指向头节点he
15、ad。 (2)主要考查考生对动态分配的掌握,用 new为节点 p动态分配存储空间,节点 p为 node类型,因此直接使用 newnode分配空间并将首地址赋给 p即可。 (3)程序要求插入该节点,应调用 Insert函数,并将指针 p作为函数的实参。三、B综合应用题/B(总题数:1,分数:40.00)3.请使用 VC6或使用答题菜单打开考生文件夹 proj3下的工程 prog3,其中声明了 ValArray类,该类在内部维护一个动态分配的 int型数组 v。ValArray 类的成员函数 cycle用于对数组元素进行向左循环移动。调用一次 cycle后,数组的第二个元素至最后一个元素都将向左移
16、动一个位置,而最左端的元素将循环移动到最右端位置上。例如,若 ValArray表示的数组为1,2,3,4,5,则第一次调用 cycle后,数组变为2,3,4,5,1,第二次调用 cycle后,数组变为3,4,5,1,2,依次类推。请编写成员函数cycle。在 main函数中给出了一组测试数据,此情况下程序的输出应该是: v=1,2,3,4,5 v=2,3,4,5,1 v=3,4,5,1,2 v=4,5,1,2,3 v=5,1,2,3,4 要求: 补充编制的内容写在“/*333*”与“/*666*”之间,不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out.dat中。输出函数 wri
17、teToFile已经编译为 obj文件,并且在本程序中调用。 /ValArray.h #include iostream using namespace std; class ValArray int* v; int size; public: ValArray const int* p, int n): size (n) v = new intsize; for (int i = 0; isize; i+) vi = pi; ValArray() delete v; void cycle (); void print(ostream for (int i = 0; i size-1; i+)
18、 out vi “,“; out vsize-1 ; ; void writeToFile (const char * ); /main. cpp #include “ValArray. h“ void ValArray:cycle () /将数组 v中的 size个整数依次移动到它的前一个单元,其中第一个整数移到原来最后元素所在单元。 /* 333* /* 666* int main ( ) const int a = 1, 2, 3, 4, 5 ; ValArray v(a, 5); for (int i = 0; i 5; i+) cout “v = “; v.print (cout);
19、 cout endl; v.cycle(); writeToFile (“); return 0; (分数:40.00)_正确答案:(for(int i=0; isize-1; i+) /从 0到 size2 遍历整数组 v,把前位与后位值相互交换 int temp=vi; /把 vi赋值给 temp vi=vi+1; /把 vi+1赋值给 vi vi+1=temp; /temp赋值给 vi+1 )解析:考点 本题考查 ValArray类,其中涉及动态数组、构造函数、析构函数、const 函数和成员函数。解析 程序要将数组 v中的 size个整数依次移动到它的前一个单元,其中第一个整数移到原来最后元素所在的单元。for 循环语句用于遍历整个数组,每循环一次便将当前元素与后一个元素互换,因此循环变量的取值范围是 0size-2,最后一个元素无须遍历。