快速业务通道

数据结构学习(C++)之单链表

作者 佚名技术 来源 程序设计 浏览 发布时间 2012-06-30
data;
   }
   else
   {
    return NULL;
   }
  }
  void Insert(const Type &value)//在当前节点的后面插入节点,不改变current
  {
   Node<Type> *p = new Node<Type>(value, current->link);
   current->link = p;
  }
  BOOL InsertBefore(const Type &value)//在当前节点的前面插入一节点,不改变current,改变prior
  {
   Node<Type> *p = new Node<Type>(value);
   if (prior != NULL)
   {
    p->link = current;
    prior->link = p;
    prior = p;
    return TURE;
   }
   else return FALSE;
  }
  BOOL Locate(int i)//移动current到第i个节点
  {
   if (i <= -1) return FALSE;
    current = first->link;
    for (int j = 0; current != NULL && j < i; j++, current = current->link)
     prior = current;
     if (current != NULL) return TURE;
     else return FALSE;
  }
  void First()//移动current到表头
  {
   current = first;
   prior = NULL;
  }
  void End()//移动current到表尾
  {
   if (last->link != NULL)
   {
    for ( ;current->link != NULL; current = current->link)
     prior = current;
     last = current;
   }
   current = last;
  }
  BOOL Find(const Type &value)//移动current到数据等于value的节点
  {
   if (IsEmpty()) return FALSE;
   for (current = first->link, prior = first; current != NULL && current->data != value;
   current = current->link)
    prior = current;
    if (current != NULL) return TURE;
    else return FALSE;
  }
  BOOL Remove()//删除当前节点,current指向下一个节点,如果current在表尾,执行后current = NULL
  {
   if (current != NULL && prior != NULL)
   {
    Node<Type> *p = current;
    prior->link = p->link;
    current = p->link;
    delete p;
    return TURE;
   }
   else return FALSE;
  }
  BOOL RemoveAfter()//删除当前节点的下一个节点,不改变current
  {
   if (current->link != NULL && current != NULL)
   {
    Node<Type> *p = current->link;
    current->link = p->link;
    delete p;
    return TURE;
   }
   else return FALSE;
  }
  friend ostream & operator << (ostream & strm, List<Type> &l)
  {
   l.First();
   while (l.current->link != NULL) strm << *l.Next() << " " ;
    strm << endl;
    l.First();
    return strm;
  }
  protected:
  /*主要是为了高效的入队算法所添加的。因为Insert(),Remove(),RemoveAfter()有可能改变last但没有改变last所以这个算法如果在public里除非不使用这些,否则不正确。但是last除了在队列中非常有用外,其他的时候很少用到,没有必要为了这个用途而降低Insert(),Remove()的效率所以把这部分放到protected,实际上主要是为了给队列继承*/ void LastInsert(const Type &value)
 {
  Node<Type> *p = new Node<Type>(value, last->link);
  last->link = p;
  last = p;
 }
 void Initialize()//当表为空表时使指针复位
 {
  current = last = first;
  prio

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号