数据结构学习(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 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |
你可能对下面的文章感兴趣
关于数据结构学习(C++)之单链表的所有评论