首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程pmj3,其中声明了一个单向链表类sList。sLst的成员函数Prepend的功能是在链表头部加入一个新的元素。请编写成员函数Prepend。在main函数中给出了一组测试数据,此时程序的输出
请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程pmj3,其中声明了一个单向链表类sList。sLst的成员函数Prepend的功能是在链表头部加入一个新的元素。请编写成员函数Prepend。在main函数中给出了一组测试数据,此时程序的输出
admin
2017-07-04
68
问题
请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程pmj3,其中声明了一个单向链表类sList。sLst的成员函数Prepend的功能是在链表头部加入一个新的元素。请编写成员函数Prepend。在main函数中给出了一组测试数据,此时程序的输出应为:
B一>A一>
###
A一>
###
A一>
###
exiting inner block
exiting outer block
注意:只在函数Prepend的“//**********333**********”和“//**********666**********”之间填入若干语句,不要改动程序中的其他内容。
//SList.h
struct sListItem{
char data;
sListItem*next;
};
class sList{
public:
sList():h(0){)
//0表示空链表
~sList();
void Prepend(char c);
//在链表前端加入元素
void Del();
//删除链表首元素
sListItem*First()const{return
h;}
//返回链表首元素
void Print()const;
//打印链表内容
void Release();
//销毁链表
private:
sListItem* h;
//链表头
};
void writeToFile(const char* );
//main.cpp
#include
#include”sList.h”
us ing namespace std;
sList::一sList()
{
Release();
}
void sList::Prepend(char C)
{
//*******333********
//********666********
}
void sList::Del()
{
sListItem*temp=h;
h=h一>next;
delete temp;
}
void sList::Print()const
{
sListItem*temp=h;
while(temp!=0)
//判断是否到达链表尾部
{
cout<
data<<”一>”;
temp=temp一>next;
}
cout<<”\n###”<
}
void sList::Release()
{
while(h!=0)
Del();
}
int main()
{
sLisL*ptr;
{
sList obj;
obj.Prepend(’A’);
obj.Prepend(’B’);
obj.Print();
obj.Del();
obj.Print();
pfir=&obj;
pLr一>Print();
tout<<”exiting inner block”<<
end1;
}
couL<<”exiting outer block”<<
endl;
writeToFile(””);
return 0;
}
选项
答案
sLiStItem*temp=new sLiStItern; //动态分配空间给结构体ternp的指针 terap一>data=c; //把c赋值于结构体temp成员data ternp一>next=h; //把h赋值于结构ternp体成员next h=temp; //把temp赋值给h,即h指向temp指向的空间
解析
主要考查考生对链表的掌握,成员函数Prepend的功能是在链表头部加入一个新元素。形参c是一个char型变量,因此要定义一个新的结构体指针temp,并给它分配sListItem类型空间,把形参c中的值赋给temp的数据域,并使temp通过指针链接到链表上。
转载请注明原文地址:https://kaotiyun.com/show/7QAp777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
已知n是一个int型变量,下列语句中错误的是
下列程序中的重载函数disp()发生错误,错误原因是【 】。#include<iostream,h>classSample{priva
设px是指向一个类动态对象的指针变量,则执行"delete px;"语句时,将自动调用该类的【 】。
设有如下说明 typedef struct {int n;char c;double x;}STD; 则有以下选项,能正确定义结构体数组并赋初值的语句是
下列程序完成从文件读取文件显示的同时写入第二个文件,则在程序中划线部分应该出现的语句是【 】。#include<iostream,h>#include<fstream,h>voidmain(){fstreamfilel,file2
关于友元的描述中错误的是
设有n元关系R及m元关系S,它们分别有p、q个元组,则关系R与S经笛卡尔积记为R×S,该关系是一个n+m元关系,那么其元组个数是()。
read函数的功能是从输人流中读取( )。
C++本身没有定义I/O操作,但I/O操作包含在C++实现中。C++标准库iostream提供了基本的I/O类。I/O操作分别由类istream和()提供。
以下选项中合法的用户标识符是
随机试题
甲和乙同为药品批发企业,其所持有的《药品经营许可证》载明的经营范图为麻醉药品、精神药品、医疗用毒性药品、化学原料药及其制剂、杭生素原料药及其制剂。甲企业和乙企业经营范围明确具有经营蛋白同化制剂、肽类激素经营资质。丙是药品零售企业,经营方式是零售(连锁),经
LiMing’shandwritingisbetterthan____intheclass.
根据HIV的感染途径,如何采取有效措施预防HIV感染?
凝血因子Ⅱ、Ⅶ、Ⅸ、Ⅹ在肝脏合成依赖于
分批偿还债券是在发行同一种债券的当时,就为不同编号或不同发行对象的债券规定了不同的到期日。()
关于布雷顿森林体系运行特征的说法,错误的是()。
许多古人的名与字有一定联系,“闻名即知其字,闻字即知其名”,如曹操字孟德,孙权字仲谋,诸葛亮字孔明。据此判断,三国人物黄盖的字是()。
某机字长32位,总线数据线宽度是16位,一个总线周期占用4个时钟周期,总线时钟频率为10MHz,则总线带宽是()。
A、 B、 C、 D、 E、 F
WhobroughtsilktoEuropeinthethirteenthcentury?
最新回复
(
0
)