单链表的结点类(ListNodeclass)和链表类(Listclass)的.doc

单链表的结点类(ListNodeclass)和链表类(Listclass)的.doc

  1. 1、本文档共15页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
单链表的结点类(ListNodeclass)和链表类(Listclass)的.doc

PAGE  第3章 链表 PAGE  PAGE 24 单链表的结点类(ListNode class)和链表类(List class)的类定义。 template class Type class List; //前视的类定义 template class Type class ListNode { //链表结点类的定义 friend class ListType; //List类作为友元类定义 private: Type data; //数据域 ListNodeType *link; //链指针域 public: ListNode ( ) : link (NULL) { } //仅初始化指针成员的构造函数 ListNode ( const Type item ) : data (item), link (NULL) { } //初始化数据与指针成员的构造函数 ListNodeType * getNode ( const Type item, ListNodeType *next = NULL ) //以item和next建立一个新结点 ListNodeType * getLink ( ) { return link; } //取得结点的下一结点地址 Type getData ( ) { return data; } //取得结点中的数据 void setLink ( ListNodeType * next ) { link = next; } //修改结点的link指针 void setData ( Type value ) { data = value; } //修改结点的data值 }; template class Type class List { //单链表类定义 private: ListNodeType *first, *current; //链表的表头指针和当前元素指针 public: List ( const Type value ) { first = current = new ListNodeType ( value ); } //构造函数 ~List ( ) { MakeEmpty ( ); delete first; } //析构函数 void MakeEmpty ( ); //将链表置为空表 int Length ( ) const; //计算链表的长度 ListNodeType * Find ( Type value ); //搜索含数据value的元素并成为当前元素 ListNodeType * Locate( int i ); //搜索第i个元素的地址并置为当前元素 Type * GetData ( ); //取出表中当前元素的值 int Insert ( Type value ); //将value插在表当前位置之后并成为当前元素 Type *Remove ( ); //将链表中的当前元素删去, 填补者为当前元素 ListNodeType * Firster ( ) { current = first; return first; } //当前指针定位于表头结点 Type *First ( ); //当前指针定位于表中第一个元素并返回其值 Type *Next ( ); //将当前指针进到表中下一个元素并返回其值 int NotNull ( ) { return current != NULL; } //表中当前元素空否?空返回1, 不空返回0 int NextNotNull ( ) { return current != NULL current-link != NULL; } //当前元素下一元素空否?空返回1, 不空返回0 }; 3-1线性表可用顺序表或链表存储。试问: (1) 两种存储表示各有哪些主要优缺点? (2) 如果有n个表同时并存,并且在处理过程中各表的长度会动态发生变化,表的总数也可能自动改变、在此情况下,应选用哪种存储表示?为什么? (3) 若表的总数基本稳定,且很少进行插入和删除,但要求以最快的速度存取表中的元素,这时,应采用哪种

文档评论(0)

170****0532 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

版权声明书
用户编号:8015033021000003

1亿VIP精品文档

相关文档