首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
使用VC6打开考生文件夹下的源程序文件modi3.cpp,阅读下列程序说明和代码,功能如下: 从屏幕输入数字,然后由大到小插入指定的链中。当输入0时,表示输出的数据已经输入完成,然后把数据打印到屏幕,然后释放内存。 其中定义的类并不完整,按
使用VC6打开考生文件夹下的源程序文件modi3.cpp,阅读下列程序说明和代码,功能如下: 从屏幕输入数字,然后由大到小插入指定的链中。当输入0时,表示输出的数据已经输入完成,然后把数据打印到屏幕,然后释放内存。 其中定义的类并不完整,按
admin
2015-05-30
23
问题
使用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全国计算机二级
相关试题推荐
下列对基类和派生类关系的描述中,错误的是______。
每个类______构造函数。
不能把字符串“Hello!”赋给数组的语是______。
数据的逻辑独立性是指______。
有如下程序:#include<iostream>usingnamespacestd;classsample{private:intx,y;public:sample(inti
在深度为5的满二叉树中,叶子结点的个数为()。
冒泡排序在最好情况下时间复杂度为【】。
当将E-R模型转换为关系模型时,对于两实体间m:n联系,必须对“联系”单独建立______,用来联系双方实体。
以下函数模板max的功能是:返回数组a中最大元素的值。请将横线处缺失部分补充完整。template<typenameT>Tmax(Ta[],intn){Tm=a[0];for(inti=1;i<n;i++)
随机试题
银行票据的签发(主要指本票)()
下列概念除了哪项都是错误的
A.双氯芬酸片B.硝普钠注射液C.降钙素鼻喷雾剂D.阿司匹林片E.头孢呋辛酯片需密闭,在2~10℃冷处保存的药品是()
低应变反射波法可用于检测(或估计)灌注桩的()。
经股东大会批准,M公司2010年1月1日实施一项股权激励计划,具体内容为:M公司授予其100名中层以上管理人员每人1000份现金股票增值权。可行权日为2013年12月31日。该增值权应在2015年12月31日之前行使完毕。授予日M公司股票市价为每股5元,截
公安机关奖励工作应当坚持精神鼓励与物质奖励相结合,以物质奖励为主的原则。()
管理规章是行政文书,具有行政效力、组织效力或纪律效力。()
关于茶文化,说法不正确的是()。
下列关于计算机病毒的叙述中,不正确的是( )。
Whatdoesthepassagemainlydiscuss?WhatregularservicedidTheAssociatedPressandUnitedPressInternationalbegintoof
最新回复
(
0
)