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

#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;              // 從表中當(dāng)前位置插入元素
        virtual bool append( const Elem& )= 0;              // 從表中后面插入元素
        virtual bool remove( Elem& )= 0;                    // 移除該元素,并且用引用返回該元素
        virtual void setStart() = 0;                        // 將表當(dāng)前位置指向第一個(gè)
        virtual void setEnd() = 0;                          // 將表當(dāng)前位置指向最后元素
        virtual void pre() = 0;                            // 將指針移向當(dāng)前位置前一個(gè)
        virtual void next() = 0;                            // 將指針移向當(dāng)前位置的下一個(gè)
        virtual int  rightLength()          const= 0;       // 指針后面數(shù)據(jù)的大小
        virtual int  leftLength()           const= 0;       // 指針前面數(shù)據(jù)的大小
        virtual bool setPos( int pos )= 0;                  // 設(shè)置當(dāng)前指針
        virtual bool getValue( Elem& )      const= 0;       // 獲得當(dāng)前指針?biāo)冈?/span>
        virtual void print()                const= 0;       // 輸出信息

        
virtual bool find( Elem const& data )= 0;           //  能否在表中找到元素 data
        virtual int  length()               const= 0;       //  整個(gè)表的長(zhǎng)度
        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;


/////////////////////////////////////////////////////////
//           結(jié)點(diǎn)類, 使用可利用空間表實(shí)現(xiàn)
/////////////////////////////////////////////////////////


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


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;
}


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



/////////////////////////////////////////////////////////////////
///  鏈表實(shí)現(xiàn)
/////////////////////////////////////////////////////////////////



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) 評(píng)論(2)  編輯 收藏 引用

評(píng)論:
# re: 線性表抽象數(shù)據(jù)結(jié)構(gòu)(c++模板實(shí)現(xiàn)) 2009-03-21 00:46 | reason
你這blog全是代碼啊,很強(qiáng)大  回復(fù)  更多評(píng)論
  
# re: 線性表抽象數(shù)據(jù)結(jié)構(gòu)(c++模板實(shí)現(xiàn)) 2009-03-21 20:44 | Darren
@reason
說白了就是保存代碼用的
呵呵  回復(fù)  更多評(píng)論
  

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品免费观看| 欧美日韩精选| 一本色道久久| 一本久道久久综合狠狠爱| 一级成人国产| 亚洲欧美综合网| 欧美在线视频a| 免费观看成人| 欧美日韩中文字幕在线视频| 欧美色欧美亚洲另类二区| 国产精品久久久久久久久久免费看 | 久久久久久999| 猛男gaygay欧美视频| 亚洲激情电影中文字幕| 亚洲乱亚洲高清| 欧美一区二区三区在| 免费的成人av| 国产精品日韩欧美一区二区三区| 国产一区清纯| 亚洲免费观看高清完整版在线观看| 亚洲免费视频网站| 免费成人黄色av| 亚洲亚洲精品在线观看 | 久久野战av| 欧美欧美在线| 国模精品一区二区三区| 欧美视频一区在线观看| 国产女主播一区二区| 在线看国产日韩| 午夜精品亚洲| 亚洲国产欧美一区| 午夜国产欧美理论在线播放| 欧美高清在线一区| 国产视频精品网| 一区二区免费在线播放| 蜜臀av性久久久久蜜臀aⅴ四虎| 洋洋av久久久久久久一区| 麻豆久久精品| 国外成人免费视频| 午夜精品在线观看| 亚洲欧洲一区| 六月婷婷一区| 国产亚洲aⅴaaaaaa毛片| 在线综合欧美| 亚洲国产专区| 免费日本视频一区| 亚洲国产一区在线观看| 久久一综合视频| 亚洲欧美韩国| 国产精品网红福利| 亚洲欧美综合| 亚洲免费一级电影| 国产精品美女主播| 午夜视频在线观看一区| 一本色道久久综合亚洲精品小说| 欧美插天视频在线播放| 亚洲激情综合| 欧美成人精品在线视频| 另类激情亚洲| 亚洲精品一区中文| 亚洲二区在线视频| 欧美激情网友自拍| aa国产精品| 一区二区不卡在线视频 午夜欧美不卡'| 欧美精品v国产精品v日韩精品 | 香蕉久久久久久久av网站| 夜夜嗨av一区二区三区中文字幕 | 国产精品久久福利| 亚洲欧美国产制服动漫| 亚洲欧美日韩国产综合在线| 国产精品红桃| 欧美专区在线| 久久亚洲影院| 99v久久综合狠狠综合久久| 日韩视频在线免费| 国产精品专区一| 久久在线精品| 欧美成人视屏| 亚洲女同精品视频| 久久精品免费电影| 亚洲美女淫视频| 亚洲乱码一区二区| 国产亚洲精品资源在线26u| 亚洲精品一区二区三区在线观看| 国产一级揄自揄精品视频| 久久久九九九九| 欧美在线看片a免费观看| 一区二区三区无毛| 亚洲国产小视频在线观看| 欧美日韩国产一区精品一区| 午夜精品久久久| 老司机午夜精品| 亚洲一区亚洲二区| 久久久久久高潮国产精品视| 99国产精品久久| 欧美一级精品大片| 亚洲福利久久| 亚洲老司机av| 激情久久影院| av成人免费| 激情欧美一区| 亚洲人在线视频| 国产一区二区精品久久| 亚洲欧洲日产国产综合网| 国产欧美日韩在线| 亚洲免费观看高清完整版在线观看熊| 国产午夜精品久久久| 欧美国产日韩亚洲一区| 国产欧美亚洲日本| 亚洲精品国产品国语在线app| 国产精品私人影院| 亚洲精品老司机| 韩国女主播一区二区三区| 亚洲美洲欧洲综合国产一区| 在线欧美影院| 欧美亚洲视频| 亚洲免费影视第一页| 欧美第一黄色网| 久久久久久久一区| 国产精品jizz在线观看美国| 欧美不卡三区| 一区二区亚洲精品国产| 午夜精品久久久久久| 亚洲主播在线观看| 欧美人与性禽动交情品| 蜜桃av一区二区三区| 国产亚洲欧美日韩日本| 亚洲男女自偷自拍| 午夜精品久久久久| 国产欧美一区二区三区另类精品 | 欧美精品免费在线| 亚洲第一精品夜夜躁人人爽| 国外视频精品毛片| 欧美一区二区三区在线看 | 久久人人97超碰人人澡爱香蕉| 国产精品a级| 亚洲永久字幕| 欧美一区1区三区3区公司| 国产精品日韩| 香港成人在线视频| 欧美专区福利在线| 激情亚洲一区二区三区四区| 久久精品视频在线免费观看| 男女精品网站| 久久先锋影音av| 99riav1国产精品视频| 欧美~级网站不卡| 欧美成人一区在线| 亚洲激情婷婷| 欧美极品影院| 亚洲色图制服丝袜| 欧美一区二区三区视频在线观看 | 亚洲激情在线观看| 99re6这里只有精品| 欧美日韩精品一区二区三区| 中文在线一区| 久久精品欧美日韩精品| 伊人成人网在线看| 欧美精品亚洲二区| 亚洲视频专区在线| 久久亚洲精品视频| 夜色激情一区二区| 国产精品第13页| 久久九九精品| 亚洲精品在线观看视频| 亚洲欧美综合国产精品一区| 国产综合色产| 欧美精品www| 性做久久久久久久免费看| 欧美电影资源| 亚洲欧美日韩综合aⅴ视频| 狠狠色狠狠色综合日日91app| 欧美黄色免费网站| 亚洲伊人色欲综合网| 欧美sm视频| 性欧美办公室18xxxxhd| 亚洲国产1区| 国产伦一区二区三区色一情| 欧美成人高清| 欧美尤物一区| 中文精品视频一区二区在线观看| 蜜臀99久久精品久久久久久软件| 中国女人久久久| 亚洲国产精品毛片| 国产日产欧产精品推荐色| 欧美乱大交xxxxx| 久久久久久一区二区三区| 中日韩高清电影网| 亚洲精品一区二区在线| 男男成人高潮片免费网站| 久久国产夜色精品鲁鲁99| 中文日韩在线| 亚洲精品网站在线播放gif| 韩国精品在线观看| 国产女同一区二区| 国产精品久久久久国产精品日日| 男人的天堂亚洲在线| 久久国产精品网站| 欧美亚洲综合另类| 亚洲一区二区在线看|