首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用VC6打开考生文件夹下的源程序文件modi3.cpp,阅读下列程序说明和代码,功能如下: 从屏幕输入数字,然后由大到小插入指定的链中。当输入0时,表示输出的数据已经输入完成,然后把数据打印到屏幕,然后释放内存。 其中定义的类并不完整,按
使用VC6打开考生文件夹下的源程序文件modi3.cpp,阅读下列程序说明和代码,功能如下: 从屏幕输入数字,然后由大到小插入指定的链中。当输入0时,表示输出的数据已经输入完成,然后把数据打印到屏幕,然后释放内存。 其中定义的类并不完整,按
admin
2015-05-30
35
问题
使用VC6打开考生文件夹下的源程序文件modi3.cpp,阅读下列程序说明和代码,功能如下:
从屏幕输入数字,然后由大到小插入指定的链中。当输入0时,表示输出的数据已经输入完成,然后把数据打印到屏幕,然后释放内存。
其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。
(1)在父节点的Next中保存新插入的节点的指针,请在注释//********1********后添加适当的语句。
(2)把pNext的子节点赋给pNext本身,请在注释//********2********后添加适当的语句。
(3)判定P的予节点不为空,如果不为空,则打印P其中的数据到屏幕,请在注释//********3********后添加适当的语句。
(4)用templ保存动态申请内存节点的链表头,请在注释//********4********后添加适当的语句。
注意:仅在函数指定位置添加语句,请勿改动主函数main与其他函数中的任何内容。
1 #include
2 Class TestClass
3 {
4 public:
5 TestClass(int data=0)
6 {
7 this->data=data;
8 thiS->next=NULL;
9 };
10 int data;
11 TestClass*next;
12 };
13 void Insert(TestClass* p,int data)
14 {
15 TestClass*temp=new TestClass(data);
16 TestClass* parent=p ;
17 TestClass* pNext=p->next ;
18 while(pNext)
19 {
20 if(data>pNext->data)
21 {
22 //********1********
23
24 temp->next=pNext;
25 return;
26 }
27 Else
28 {
29 pParent=pNext;
30 //********2********
31
32 }
33 }
34 if(pNext==NULL)
35 {
36 pParent->next=temp;
37 return;
38 }
39 }
40 void printf(TestClass* p)
41 {
42 //********3********
43 while()
44 {
45 cout<
next->data<<"";
46 p=p一>next ;
47 }
48 cout<
49 }
50 void Delete(TestClass* p)
51 {
52 //********4********
53 TestClass*templ=;
54 TestClass*temp2;
55 while(templ!=NULL)
56 i
57 temp2=templ一>next;
58 delete templ,
59 templ=temp2;
60 }
61 }
62 void main()
63 {
64 int i=0 ;
65 TestClass head;
66 do
67 {
68 int data;
69 cout<<"请输入一个数字:"<
70 cin>>data ;
j71 if(data==0)break ;
72 Insert(&head,data);
73 }while(1);
74 printf(&head);
75 Delete(&head);
76 return;
77 }
选项
答案
(1)添加语句:pParent一>next=temp ; (2)添加语句:pNext=pNext一>next; (3)将“while()”补充完整为:while(p->next!=NULL) (4)将“TestClass*templ=;”补充完整为:TestClass * templ=p->next;
解析
在VC环境下打开程序,根据题干给出的几条功能要求,对程序中给出注释下的内容逐个补全或修改。从已给定源程序的main主函数开始入手,可以看出程序通过调用类TestClass实现各种输出操作。
[解题思路]
(1)题目1要求“在父节点的Next中保存新插入的节点的指针”。对于指针的操作pParent->next为pParent的子结点,在父节点的Next中保存新插入的节点的指针,即“pParent->next=temp;”。
(2)题目2要求“把pNext的子节点赋给pNext本身”。pNext->next为pNext的子结点,把pNext的子节点赋给pNext本身,即“pNext=pNext->next;”。
(3)注释//********3********下是判定P的子节点不为空。P的子节点是p->next。程序中的“while()”缺乏P的子节点不为空的判断条件,所以修改为“while(p->next!=NULL)”。
(4)题目4要求“用templ保存动态申请内存节点的链表头”。P为链表,p->next为链表头。程序中的语句“TestClass*templ=;”中templ没有被赋值,所以修改为“TestClass*templ=p->next;”。
转载请注明原文地址:https://kaotiyun.com/show/jPNp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
表达式8&3的结果是【】。
下面对结构或类中成员的访问中,不正确的访问是______。
构造函数与析构函数所调用的虚函数是【】的函数,因此调用时实现的是【】联编。
若有如下类定义:classB{voidfunl(){}protected:doublevarl:public:voidfun2(){}};classD:public
在函数中,可以用auto、extem、register和static四个关键字中的一个来说明变量的存储类型,如果不说明存储类型,则默认的存储类型是()。
结构化程序设计思想的核心是要求程序只由顺序、循环和【】三种结构组成。
以下程序的输出结果是()。#include<iostream.h>main(){intm=5;if(m++>5)cout<<m;elsecout<<m--;}
将小写字母n赋值给字符变量one_char,正确的操作是______。
一个教师能开多门课程,一门课程有许多教师会开,实体课程与实体教师间是______。
结构化程序设计的一种基本方法是【】法。
随机试题
TheWestLaketodayisnolongerwhatitusedtobesomeyearsago.
本病可诊为:内治方药为:
磺脲类降糖药主要适用于
关于矿井开拓方式的说法,正确的是()。
下列各项不属于区域政策法规的重大变化中的相关警示信号的是()。
游客投诉的心理包括()。
依次填人横线处的词语,最恰当的一组是()。(1)有人说日本汽车比德国汽车更舒适,也有人说德国汽车比日本汽车更稳重,但这_____只是个人的不同感受,购车人还是要亲自驾驶一下才能作出判断。(2)世界上生产维生素C最先进的两步发酵法
左边给定的是纸盒的外表面,下列哪一项能由它折叠而成?
患儿,女,7岁。被蜜蜂蜇伤面部2h,此时错误处理方法是()。
已知数组arr的定义如下:intarr[5]={1,2,3,4,5};下列语句中输出结果不是5的是
最新回复
(
0
)