青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

#ifndef LIST_HPP
#define LIST_HPP

#include 
<iostream>
#include 
<string>

using namespace std;

#define DefaultListSize  1000

template
< typename Elem>
class List
{
    
public:
        
virtual void clear() = 0;                           // 清空表
        virtual bool insert( const Elem& )= 0;              // 從表中當前位置插入元素
        virtual bool append( const Elem& )= 0;              // 從表中后面插入元素
        virtual bool remove( Elem& )= 0;                    // 移除該元素,并且用引用返回該元素
        virtual void setStart() = 0;                        // 將表當前位置指向第一個
        virtual void setEnd() = 0;                          // 將表當前位置指向最后元素
        virtual void pre() = 0;                            // 將指針移向當前位置前一個
        virtual void next() = 0;                            // 將指針移向當前位置的下一個
        virtual int  rightLength()          const= 0;       // 指針后面數據的大小
        virtual int  leftLength()           const= 0;       // 指針前面數據的大小
        virtual bool setPos( int pos )= 0;                  // 設置當前指針
        virtual bool getValue( Elem& )      const= 0;       // 獲得當前指針所指元素
        virtual void print()                const= 0;       // 輸出信息

        
virtual bool find( Elem const& data )= 0;           //  能否在表中找到元素 data
        virtual int  length()               const= 0;       //  整個表的長度
        virtual bool empty()                const= 0;       //  表是否為空
};

#endif



#ifndef ALIST_HPP
#define ALIST_HPP

#include 
"List.hpp"

template
<typename Elem>
class AList: public List<Elem>
{
private:
    
int   maxSize;
    
int   listSize;
    
int   fence;
    Elem
* listArray;

public:
    AList( 
int size= DefaultListSize );
    
~AList();
    
    
void clear();
    
bool insert( const Elem& );
    
bool append( const Elem& );
    
bool remove( Elem& );
    
void setStart() ;
    
void setEnd() ;
    
void prev() ;
    
void next();
    
int  rightLength()          const;
    
int  leftLength()           const;
    
bool setPos( int pos );
    
bool getValue( Elem& )      const;
    
void print()                const;

    
int  length()               const
    
bool find( Elem const& data );
    
bool empty()                const;

    
int  getMaxSize() const;
    
int  getListSize() const;
    
int  getFence() const;

    AList
<Elem>& operator= ( AList<Elem>& t );
    Elem
& operator[]( int i );
};


template
<typename Type>
AList
<Type>::AList( int size )
{
    maxSize
= size;
    listSize
= fence= 0;

    listArray
= new Type[maxSize];
}


template
<typename Type>
AList
<Type>::~AList()
{
    delete [] listArray;
}


template
<typename Type>
void AList<Type>::clear()
{
    listSize
= fence= 0;
}


template
<typename Type>
bool AList<Type>::insert( Type const& Item )
{
    
if( listSize== maxSize ) return false;

    
forint i= listSize; i> fence; i-- )
        listArray[i]
= listArray[i-1];

    listArray[fence]
= Item;
    listSize
++;

    
return true;
}


template
<typename Type>
bool AList<Type>::append( Type const& Item )
{
    
if( listSize== maxSize ) return false;

    listArray[listSize
++]= Item;
    
return true;
}


template
<typename Type>
bool AList<Type>::remove( Type& Item )
{
    
if( rightLength()== 0 ) return false;

    
forint i= fence; i< listSize- 1++i )
        listArray[i]
= listArray[i+1];

    listSize
--;
    
return true;
}


template
<typename Type>
void AList<Type>::prev()
{
    
if(  fence> 0 ) fence--;
}


template
<typename Type>
void AList<Type>::next()
{
    
if( fence<= listSize ) fence++;
}


template
<typename Type>
int AList<Type>::rightLength() const
{
    
return listSize- fence;
}


template
<typename Type>
int AList<Type>::leftLength() const
{
    
return fence;
}

template
<typename Type>
int AList<Type>::length() const
{
    
return listSize;
}


template
<typename Type>
bool AList<Type>::setPos( int pos ) 
{
    
if( pos< 0 || pos> listSize ) return false;

    fence
= pos;
    
return true;
}

template
<typename Type>
bool AList<Type>::getValue( Type& Item ) const
{
    
if( fence< 0 || fence>= listSize ) return false;

    Item
= listArray[fence];
    
return true;
}

template
<typename Type>
void AList<Type>::setStart()
{
    fence
= 0;
}


template
<typename Type>
void AList<Type>::setEnd()
{
    fence
= listSize;
}


template
<typename Type>
bool AList<Type>::find( Type const& data )
{
    
forint i= 0; i< listSize; ++i )
    
if( listArray[i]== data ) return true;

    
return false;
}


template
<typename Type>
void AList<Type>::print() const
{
    
int t= 0;
    
for( t= 0; t< fence; ++t ) cout << listArray[t] << ' ';
    cout 
<< '|' << ' ';
    
for( t= fence; t< listSize; ++t ) cout << listArray[t] << ' ';
}


template
<typename Type>
bool AList<Type>::empty() const
{
    
return listSize== 0;
}

template
<typename Type>
AList
<Type>& AList<Type>::operator= ( AList<Type>& t )
{
    maxSize
= t.getMaxSize();
    listSize
= t.getListSize();
    fence
= t.getFence();

    listArray
= new Type[maxSize];
    
forint i= 0; i< listSize; ++i )
    listArray[i]
= t[i];
    
    
return *this;
}


template
<typename Type>
Type
& AList<Type>::operator[]( int i )
{
    
return listArray[i];
}


template
<typename Type>
int AList<Type>::getMaxSize() const
{
    
return maxSize;
}


template
<typename Type>
int AList<Type>::getListSize() const
{
    
return listSize;
}


template
<typename Type>
int AList<Type>::getFence() const
{
    
return fence;
}

#endif





#ifndef LLIST_HPP
#define LLIST_HPP

#include 
"list.hpp"
#include 
<iostream>

using namespace std;


/////////////////////////////////////////////////////////
//           結點類, 使用可利用空間表實現
/////////////////////////////////////////////////////////


//////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////


template
<typename Type>
class CLink
{
    
private:
        
static CLink<Type>* freelist;

    
public:
        Type   element;
        CLink
* next;

    
public:
        
void* operator new   ( size_t );
        
void  operator delete( void*  );

        CLink();
        CLink( Type, CLink
<Type>* );
};

template
<typename Type>
CLink
<Type>* CLink<Type>::freelist= NULL;

template
<typename Type>
CLink
<Type>::CLink()
{}

template
<typename Type>
CLink
<Type>::CLink( Type a, CLink<Type>* b ):
element(a), next(b)
{}

template
<typename Type>
void* CLink<Type>::operator new( size_t )
{
    
if( freelist== NULL ) return ::new CLink<Type>;

    CLink
<Type>* temp= freelist;
    freelist
= freelist->next;

    
return temp;
}

template
<typename Type>
void CLink<Type>::operator delete( void* t )
{
    ((CLink
<Type>*)t)->next= freelist;

    freelist
= ( CLink<Type>* )t;
}


/////////////////////////////////////////////////////////////////
/////////////////////////////////////////////////////////////////



/////////////////////////////////////////////////////////////////
///  鏈表實現
/////////////////////////////////////////////////////////////////



template
<typename Type>
class LList: public List<Type>
{
    
private:
        CLink
<Type>* head, *tail, *fence;
        
int  leftcnt, rightcnt;

    
public:
        LList( 
int size= DefaultListSize );
        
~LList();

        
void clear();
        
bool insert( const Type& );
        
bool append( const Type& );
        
bool remove( Type& );
        
void setStart() ;
        
void setEnd() ;
        
void pre() ;
        
void next();
        
int  rightLength()          const;
        
int  leftLength()           const;
        
bool setPos( int pos );
        
bool getValue( Type& )      const;
        
void print()                const;

        
int  length()               const
        
bool find( Type const& data );
        
bool empty()                const;

        
void init();
        
void removeall();

        
bool setvalue( int pos, Type t );
        
bool setvalue( Type t );
};

template
<typename Type>
LList
<Type>::LList( int size )
{
    init();
}


template
<typename Type>
void LList<Type>::init()
{
    fence
= tail= head= new CLink<Type>;
    leftcnt
= rightcnt= 0;
}

template
<typename Type>
void LList<Type>::removeall()
{
    
while( head!= NULL )
    {
        fence
= head;
        head
= head->next;
        delete fence;
    }
}

template
<typename Type>
LList
<Type>::~LList()
{
    removeall();
}

template
<typename Type>
void LList<Type>::clear()
{
    removeall();
    init();
}

template
<typename Type>
void LList<Type>::setStart()
{
    fence
= head;
    rightcnt
+= leftcnt;
    leftcnt
= 0;
}

template
<typename Type>
void LList<Type>::setEnd()
{
    fence
= tail;
    leftcnt
+= rightcnt;
    rightcnt
= 0;
}

template
<typename Type>
void LList<Type>::next()
{
    
if( fence!= tail ) fence= fence->next, rightcnt--, leftcnt++;
}

template
<typename Type>
int LList<Type>::leftLength() const
{
    
return leftcnt;
}

template
<typename Type>
int LList<Type>::rightLength() const
{
    
return rightcnt;
}

template
<typename Type>
bool LList<Type>::getValue( Type& it ) const
{
    
if( rightcnt== 0 ) return false;

    it
= fence->next->element;
    
return true;
}

template
<typename Type>
bool LList<Type>::insert( const Type& item )
{
    fence
->next= new CLink<Type>( item, fence->next );

    
if( tail== fence ) tail= fence->next;
    rightcnt
++;

    
return true;
}

template
<typename Type>
bool LList<Type>::append( Type const& Item )
{
    tail
= tail->next= new CLink<Type>( Item, NULL );
    rightcnt
++;

    
return true;
}

template
<typename Type>
bool LList<Type>::remove( Type& it )
{
    
if( fence->next== NULL ) return false;

    it
= fence->next->element;

    CLink
<Type>* ltemp= fence->next;
    fence
->next= ltemp->next;
    
if( tail== ltemp ) tail= fence;

    delete ltemp;
    rightcnt
--;

    
return true;
}

template
<typename Type>
void LList<Type>::pre()
{
    CLink
<Type>* temp= head;

    
if( fence== head ) return;
    
while( temp->next!= fence ) temp= temp->next;
    fence
= temp;

    leftcnt
--, rightcnt++;
}

template
<typename Type>
bool LList<Type>::setPos(  int pos )
{
    
if( pos< 0 || pos> rightcnt+ leftcnt ) return false;

    fence
= head;
    
forint i= 0; i< pos; ++i ) fence= fence->next;

    
return true;
}

template
<typename Type>
bool LList<Type>::setvalue( int pos, Type Item )
{
    
if( pos< 0 || pos> rightcnt+ leftcnt ) return false;

    fence
= head;
    
forint i= 0; i< pos; ++i ) fence= fence->next;

    fence
->element= Item;
}

template
<typename Type>
bool LList<Type>::setvalue( Type Item )
{
    
if( fence= head ) return false;

    fence
->element= Item;
    
return true;
}


template
<typename Type>
int LList<Type>::length() const
{
    
return rightcnt+ leftcnt;
}

template
<typename Type>
bool LList<Type>::empty() const
{
    
return rightcnt+ leftcnt== 0;
}

template
<typename Type>
bool LList<Type>::find( Type const& Item )
{
    CLink
<Type>* temp;

    
for( temp= head; temp; temp= temp->next )
        
if( temp->element== Item ) return true;

    
return false;
}


template
<typename Type>
void LList<Type>::print() const
{
    CLink
<Type>* temp= head;

    cout 
<< "";
    
while( temp!= fence )
    {
        cout 
<< temp->next->element << " ";
        temp
= temp->next;
    }

    cout 
<< "";
    
while( temp->next!= NULL )
    {
        cout 
<< temp->next->element << ' ';
        temp
= temp->next;
    }

    cout 
<< "" << endl;
}


#endif

posted on 2009-03-15 10:47 Darren 閱讀(918) 評論(2)  編輯 收藏 引用

評論:
# re: 線性表抽象數據結構(c++模板實現) 2009-03-21 00:46 | reason
你這blog全是代碼啊,很強大  回復  更多評論
  
# re: 線性表抽象數據結構(c++模板實現) 2009-03-21 20:44 | Darren
@reason
說白了就是保存代碼用的
呵呵  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            美腿丝袜亚洲色图| 欧美成人69| 欧美影院一区| 亚洲精品美女在线| 欧美一区二区三区啪啪 | 国产精品扒开腿做爽爽爽视频| 尤妮丝一区二区裸体视频| 午夜国产精品视频| 中文国产一区| 欧美午夜影院| 亚洲夜间福利| 一区二区三区视频在线| 欧美日韩国产黄| 夜久久久久久| 亚洲久久一区| 欧美四级电影网站| 亚洲影视九九影院在线观看| 日韩天堂在线视频| 欧美日韩中字| 午夜精品久久久久久99热| 在线视频亚洲欧美| 国产精品男gay被猛男狂揉视频| 亚洲一区在线直播| 亚洲一区二区三区精品视频| 国产老女人精品毛片久久| 欧美一区二区三区精品| 欧美在线视频网站| 亚洲黄色在线观看| 日韩视频免费在线观看| 国产精品久久久久久久久久免费| 亚洲午夜一区| 午夜亚洲福利在线老司机| 狠狠色2019综合网| 亚洲电影免费在线观看| 欧美视频国产精品| 欧美自拍偷拍午夜视频| 久久久久久有精品国产| 亚洲美女性视频| 亚洲影院在线观看| 亚洲国产1区| 亚洲一区二区三区视频| 国产一区二区你懂的| 欧美激情视频网站| 欧美日韩国产欧美日美国产精品| 欧美一区二区三区四区夜夜大片| 久久精品首页| 亚洲一区国产一区| 另类人畜视频在线| 亚洲男人的天堂在线| 久久久精品999| 亚洲免费人成在线视频观看| 久久se精品一区精品二区| 国产综合激情| 亚洲美女av网站| 国产亚洲欧美一区二区| 亚洲黄色成人| 狠狠色丁香婷婷综合| 99视频精品在线| 亚洲视频观看| 亚洲精品美女久久7777777| 亚洲欧洲99久久| 日韩视频久久| 久热re这里精品视频在线6| 午夜精品区一区二区三| 麻豆精品视频在线观看视频| 欧美影院久久久| 欧美日韩精品在线视频| 免播放器亚洲一区| 国产精品一二一区| 99视频精品在线| 亚洲精品在线一区二区| 久久福利精品| 欧美一区在线直播| 欧美日韩一区在线视频| 欧美高清在线视频观看不卡| 国产午夜亚洲精品羞羞网站 | 欧美日韩国产区一| 农夫在线精品视频免费观看| 国产精品―色哟哟| 亚洲视频精选在线| 一区二区精品在线| 欧美日韩国产一区二区三区| 女人香蕉久久**毛片精品| 国产亚洲精品久久飘花| 亚洲在线免费观看| 亚洲一区二区三区午夜| 欧美日韩亚洲一区二区三区在线| 欧美激情在线| 最新成人在线| 欧美不卡三区| 亚洲黄色成人久久久| 日韩视频免费在线观看| 欧美精品一区二区精品网| 91久久在线| 9国产精品视频| 欧美日本三区| 夜夜嗨av一区二区三区中文字幕 | 欧美日韩hd| 亚洲精品一二区| 亚洲视频欧美视频| 欧美视频一区二| 亚洲午夜激情网站| 欧美一级一区| 国内视频精品| 久久国产精品一区二区| 免费成人美女女| 亚洲欧洲精品一区二区三区波多野1战4| 久久先锋资源| 亚洲欧洲综合另类在线| 亚洲免费观看在线观看| 欧美日韩国产免费| 亚洲一区二区在线免费观看视频| 欧美在线视频一区二区| 国内精品写真在线观看| 老司机免费视频一区二区| 亚洲国产精品国自产拍av秋霞| 一本一本久久a久久精品综合麻豆| 欧美色图一区二区三区| 亚洲欧美日本在线| 久久久久五月天| 亚洲电影欧美电影有声小说| 欧美人与性动交a欧美精品| 久久精品91久久香蕉加勒比| 国产主播一区二区三区四区| 免费成人激情视频| 一区二区三区 在线观看视频| 性久久久久久久久久久久| 黄色精品一区二区| 欧美精品午夜视频| 欧美一区午夜视频在线观看| 欧美激情一区二区三区蜜桃视频| 中文国产成人精品| 在线精品国产欧美| 国产精品都在这里| 久久精品国产99国产精品| 欧美成人激情视频| 亚洲一区二区视频在线观看| 激情五月综合色婷婷一区二区| 欧美福利电影在线观看| 欧美一区二区三区在线观看| 91久久久在线| 久久国产欧美日韩精品| 99精品热6080yy久久| 国产一区二区三区成人欧美日韩在线观看 | 亚洲欧洲日本专区| 国产美女精品免费电影| 欧美激情2020午夜免费观看| 亚洲欧美日韩另类| 亚洲欧洲偷拍精品| 免费在线欧美黄色| 久久福利电影| 亚洲欧美国产一区二区三区| 亚洲美女视频网| 在线精品国产成人综合| 国产日韩欧美电影在线观看| 欧美日韩视频一区二区| 米奇777超碰欧美日韩亚洲| 先锋影音久久久| 亚洲少妇最新在线视频| 亚洲日本免费电影| 欧美成人精品在线| 久久久亚洲高清| 欧美一区二区免费观在线| 亚洲一区二区三区欧美| 日韩视频在线观看免费| 亚洲国产精品va在线看黑人动漫| 国产亚洲欧美日韩精品| 国产欧美一区二区在线观看| 国产精品高潮粉嫩av| 欧美日韩国产精品一区| 欧美激情中文字幕在线| 久久深夜福利| 久久先锋资源| 女人色偷偷aa久久天堂| 久热精品视频在线免费观看| 久久久www| 老司机午夜精品| 美女被久久久| 欧美成人黑人xx视频免费观看| 久久综合九九| 玖玖玖国产精品| 免费观看日韩| 久久五月激情| 久久久精品日韩| 久久亚洲精品视频| 麻豆av一区二区三区久久| 美国十次成人| 欧美国产欧美亚州国产日韩mv天天看完整| 久久在线免费视频| 欧美激情国产日韩| 亚洲国产精品国自产拍av秋霞| 中文在线不卡| 亚洲尤物在线视频观看| 亚洲欧美激情一区| 欧美中文字幕在线观看| 久久久蜜桃精品| 欧美激情偷拍| 夜夜嗨一区二区| 亚洲欧洲99久久| 美女999久久久精品视频|