list練習實現

來源:互聯網
上載者:User

#ifndef _LIST_H
#define _LIST_H
#include <iostream>

template<class T>
class Node
{
public:
    Node(){}//建構函式
    Node(T x,Node<T> *pNext = NULL,Node<T> *pPrev = NULL)
        :m_x(x),m_pNext(pNext),m_pPrev(pPrev){}
    ~Node(){}
    T m_x;//x座標
    Node<T> *m_pNext;//前指標
    Node<T> *m_pPrev;//後指標
};

template<class T>
class List
{
public:
    List()
    {
        m_pHead = m_pTail = NULL;
    }
    List(T x)
    {
        m_pHead = m_pTail = new Node(x);
    }
    List(List<T> &list);

    //解構函式
    ~List();

    //前插節點
    bool PushFrontPont(T x);

    //後插節點
    bool PushBackPoint(T x);

    //前出節點
    bool PopFrontPoint();

    //後出節點
    bool PopBackPoint();

    //查詢節點
    Node<T>*FindPoint(T x);

    //插入節點
    bool InsertPoint(T x, int pos);
   
    //刪除節點
    bool DeletePoint(T x);

    //輸出樹
    void FrontOutPutTree();
   
    //輸出樹
    void BackOutPutTree();
   
    //getfront
    Node<T> * GetFront(){return m_pHead;    }

    //getend
    Node<T> * GetEnd(){  return m_pTail;}

    bool Empty();

    //賦值運算子多載
    //friend BitTree<T> & operator= (BitTree<T> &bt);

    //加號運算子多載
    //friend BitTree<T> & operator+(BitTree<T> &lbt,BitTree<T> &rbt);

    // >運算子多載
    //friend bool operator> (BitTree<T> &lbt,BitTree<T> &rbt);

    // <運算子多載
    //friend bool operator< (BitTree<T> &lbt,BitTree<T> &rbt);

private:
    Node<T> *m_pHead;//頭指標
    Node<T> *m_pTail;//尾指標
};
#endif

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.