| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1147 人关注过本帖, 1 人收藏
标题:请教链表类
只看楼主 加入收藏
lqqnjust
Rank: 1
来 自:江苏南通
等 级:新手上路
帖 子:52
专家分:0
注 册:2008-7-17
结帖率:100%
收藏(1)
 问题点数:0 回复次数:11 
请教链表类
我对链表对不太熟悉,麻烦知道的给个例子,数据内容简单点没关系,最好包含,创建链表,插入结点,删除结点,查找结点,遍历,删除这些基本的链表操作,我这里先谢谢啦。
搜索更多相关主题的帖子: 链表 
2008-10-01 19:53
一眼的笑意
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2008-9-20
收藏
得分:0 
自己看吧
每一本书上都有,我推荐清华大学出版社的;
北邮出版的那本是我们院长编的,有个例子很全,把你说的都包括进出了,不过不太好懂
2008-10-01 20:46
lqqnjust
Rank: 1
来 自:江苏南通
等 级:新手上路
帖 子:52
专家分:0
注 册:2008-7-17
收藏
得分:0 
回复 2# 一眼的笑意 的帖子
给个书名吧。我去查查

正在学习编程。希望各位不吝赐教,(*^__^*) 嘻嘻……
2008-10-02 12:39
blueboy82006
Rank: 5Rank: 5
来 自:幻想世界
等 级:贵宾
威 望:16
帖 子:1227
专家分:57
注 册:2007-7-23
收藏
得分:0 
作一个通讯录就一切OK...

2008-10-02 13:02
中学者
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:20
帖 子:3554
专家分:80
注 册:2007-9-14
收藏
得分:0 
等等我看看我写过的还在不

樱花大战,  有爱.
2008-10-02 13:25
中学者
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:20
帖 子:3554
专家分:80
注 册:2007-9-14
收藏
得分:0 
程序代码:
template<typename _Ty>
struct node
{
public:
      _Ty value_;
       node* next_,*pre_;
       node(const _Ty& value): value_(value)
       {
            pre_ = next_ =0;
       }
       ~node(){ std::cout<<"destory..."<<std::endl;}
} ;
template<typename _Ty,class _Node=node<_Ty> >
class DList
{
public:
   typedef  _Node*  pointer;
   typedef  _Node const*  const_pointer;
   typedef  _Node&  reference;
   typedef  _Node&  const_reference;
   DList();
   DList(const DList<_Ty,_Node>& source);
   DList<_Ty,_Node>& operator=(const DList<_Ty,_Node>& source);
   ~DList();

   bool empty() const { return (head_==0); }
   int size() const { return size_; }
   pointer begin() const { return head_; }
   pointer end() const { return 0; }
   void push_front(const _Ty& value);
   void push_back(const _Ty& value);
   _Ty front() const;
   _Ty back() const;
   void pop_front();
   void pop_back();
   void Insert(const _Ty& value,pointer where_);
   void Delete(pointer where_);
   pointer Find(int pos) const;
   void reverse() ;

   void print() const
   {
       for(pointer it=head_;it!=0;it=it->next_ )
           std::cout<<it->value_<<" ";
       std::cout<<std::endl;
   }
private:
    pointer allocated() const
    {
        return static_cast<pointer>(::operator new(sizeof(_Node)));
    }
    void append(pointer where_,const _Ty& value) const
    {
        new (where_)_Node(value);
    }
    void destroy(pointer where_) const
    {
        where_->~_Node();
        ::operator delete(where_);
    }
    pointer link(pointer where_pre,pointer where_,pointer where_suc)
    {
        where_->pre_ = where_pre;
        where_->next_ = where_suc;
        if( where_pre )  where_pre->next_ = where_;
        if( where_suc )  where_suc->pre_ = where_;
        return where_;
    }
    void Swap(DList<_Ty,_Node>& source)
    {
        std::swap(head_,source.head_);
        std::swap(size_,source.size_);
    }
private:
    pointer  head_;
    int size_;
};

 //  具体实现
template<typename _Ty,class _Node >
DList<_Ty,_Node>::DList():head_(0),size_(0)
{}
template<typename _Ty,class _Node >
DList<_Ty,_Node>::~DList()
{
    for(pointer begin_=head_,current;begin_!=end();)
    {
        current=begin_;
        begin_=begin_->next_;
        destroy(current);
    }
    std::cout<<"this is ....."<<std::endl;
}
template<typename _Ty,class _Node >
DList<_Ty,_Node>::DList(const DList<_Ty,_Node>& source):head_(0),size_(0)
{
    typename DList<_Ty,_Node>::pointer begin_=source.begin();
    DList<_Ty,_Node> temp;
    for(;begin_!=source.end();begin_=begin_->next_)
    {
        temp.push_back(begin_->value_);
    }
    Swap(temp);
}
template<typename _Ty,class _Node>
DList<_Ty,_Node>& DList<_Ty,_Node>::operator= (const DList<_Ty,_Node>& source)
{
    DList<_Ty,_Node> temp(source);
    Swap(temp);
    return *this;
}
template<typename _Ty,class _Node >
void DList<_Ty,_Node>::push_front(const _Ty& value)
{
    typename DList<_Ty,_Node>::pointer node_=allocated();
    append(node_,value);
    head_=link(0,node_,head_);
    ++size_;
}
template<typename _Ty,class _Node >
void DList<_Ty,_Node>::push_back(const _Ty& value)
{
    typename DList<_Ty,_Node>::pointer node_=allocated();
    typename DList<_Ty,_Node>::pointer end_=Find(size_);
    append(node_,value);
    if( head_==0 ) head_=node_;
    else link(end_->pre_,end_,node_);
    ++size_;
}
template<typename _Ty,class _Node>
inline _Ty DList<_Ty,_Node>::front() const
{
    return head_->value_;
}
template<typename _Ty,class _Node>
inline _Ty DList<_Ty,_Node>::back() const
{
    typename DList<_Ty,_Node>::pointer node_=Find(size_);
    return node_->value_;
}
template<typename _Ty,class _Node>
void DList<_Ty,_Node>::pop_back() 
{
    typename DList<_Ty,_Node>::pointer node_p=Find(size_-1);
    typename DList<_Ty,_Node>::pointer node_s=Find(size_);
    link(node_p->pre_,node_p,0);
    destroy(node_s);
    head_=--size_?head_:0;
}
template<typename _Ty,class _Node>
void DList<_Ty,_Node>::pop_front() 
{
    typename DList<_Ty,_Node>::pointer node_=head_;
    head_=link(0,head_->next_,head_->next_->next_);
    destroy(node_);
    head_=--size_?head_:0;
}
template<typename _Ty,class _Node>
void DList<_Ty,_Node>::Insert(const _Ty& value,typename DList<_Ty,_Node>::pointer where_)
{
    typename DList<_Ty,_Node>::pointer node_=allocated();
    append(node_,value);
    if( where_==head_ ) head_=link(where_->pre_,node_,where_);
    else link(where_->pre_,node_,where_);
    ++size_;
}
template<typename _Ty,class _Node>
void DList<_Ty,_Node>::Delete(typename DList<_Ty,_Node>::pointer where_)
{
    if( where_==head_ ) head_=link(0,head_->next_,head_->next_->next_);
    else link(where_->pre_->pre_,where_->pre_,where_->next_);
    destroy(where_);
    --size_;
}
template<typename _Ty,class _Node>
typename DList<_Ty,_Node>::pointer DList<_Ty,_Node>::Find(int pos) const
{
    assert(pos>=0&&pos<=size_);
    typename DList<_Ty,_Node>::pointer node_=head_;
    for(;pos>1;--pos) node_=node_->next_;
    return node_;
}
template<typename _Ty,class _Node>
void DList<_Ty,_Node>::reverse()
{
    typename DList<_Ty,_Node>::pointer end_=Find(size_);
    for(typename DList<_Ty,_Node>::pointer x_pre=0,x=end_;end_!=0;)
    {
       end_=end_->pre_;
       x_pre=link(x_pre,x,0);
       x=end_;
       if(x_pre->pre_==0) head_=x_pre;
    }
}

樱花大战,  有爱.
2008-10-02 13:27
中学者
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:20
帖 子:3554
专家分:80
注 册:2007-9-14
收藏
得分:0 
很久以前写的...没注释-,- 自己看吧~~~
还有placement new 的运用最好改掉....因为这里不需要,这样做反而不异常安全了~

樱花大战,  有爱.
2008-10-02 13:28
中学者
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:20
帖 子:3554
专家分:80
注 册:2007-9-14
收藏
得分:0 
这个是双向链表-,- 比较容易写~~
如果要改单链的话,  只要改link函数基本就OK了... 然后把结点结构改掉.

樱花大战,  有爱.
2008-10-02 13:32
blueboy82006
Rank: 5Rank: 5
来 自:幻想世界
等 级:贵宾
威 望:16
帖 子:1227
专家分:57
注 册:2007-7-23
收藏
得分:0 
回复 6# 中学者 的帖子
顶顶...

2008-10-02 13:45
lqqnjust
Rank: 1
来 自:江苏南通
等 级:新手上路
帖 子:52
专家分:0
注 册:2008-7-17
收藏
得分:0 
回复 4# blueboy82006 的帖子
做通讯录?

正在学习编程。希望各位不吝赐教,(*^__^*) 嘻嘻……
2008-10-02 16:51
快速回复:请教链表类
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023807 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved