c++链表,求助
c++链表,求助#ifndef LIST_H
#define LIST_H
template<typename elemtype>class list_ITem
{
public:
list_item( elemtype, list_ITem<elemtype>* );
list_item( const list_ITem<elemtype>& );
const elemtype date () const;
const list_ITem<elemtype>* next() const;
void get_date ( const elemtype );
void get_next ( const list_ITem<elemtype>* );
void operator =( const list_ITem<elemtype>& );
private:
elemtype _date;
list_ITem<elemtype> *_next;
};
//单链表数据项类
//数据项类代码实现
template<typename elemtype>
list_item<elemtype>::list_ITem(elemtype ia = 0,list_ITem<elemtype> *p = 0)
{
get_date( ia );
if( p == NULL )
get_next( NULL );
else
{
get_next( p->next() );
p->get_next( this );
}
}
template<typename elemtype>
const elemtype
list_ITem<elemtype>::date() const
{
return _date;
}
template<typename elemtype> const
list_item<elemtype>* list_ITem<elemtype>::next() const
{
return _next;
}
template<typename elemtype>
void list_ITem<elemtype>::get_date( const elemtype de )
{
_date = de;
}
template<typename elemtype>
void list_ITem<elemtype>::
get_next( const list_ITem<elemtype> *pev )
{
_next = ( list_ITem<elemtype>* )pev;
}
template<typename elemtype> class list
{
public:
list();
list( const list<elemtype>& );
~list();
const int size() const;
const bool empty() const;
void insert( const elemtype, const elemtype );
void insert_front( const elemtype );
void insert_end( const elemtype );
void remove( const elemtype );
void remove_all();
void remove_front();
void print() const;
const list_ITem<elemtype>* find( const elemtype );
void operator =( const list<elemtype>& );
private:
//
void down_size();
void add_size();
//
list_ITem<elemtype> *at_front;
list_ITem<elemtype> *at_end;
list_ITem<elemtype> *at_move;
int _size;
};//链表类定义
//函数实现代码
//私有函数集合
template<typename elemtype>
void list<elemtype>::add_size()
{
++_size;
}
template<typename elemtype>
void list<elemtype>::down_size()
{
--_size;
}
//公有函数集合
template<typename elemtype>
list<elemtype>::list() {
at_front = NULL;
at_end = NULL;
_size = 0;
}
template<typename elemtype>
list<elemtype>::~list()
{
remove_all();
}
template<typename elemtype>
const bool list<elemtype>::empty() const
{
return size() == 0 ? false : true;
}
template<typename elemtype>
const int list<elemtype>::size() const
{
return _size;
}
template<typename elemtype>
void list<elemtype>::insert_front( const elemtype iva )
{
list_ITem<elemtype> *pv =
new list_ITem<elemtype>( iva, 0 );
if( !at_front )
{
at_front = at_end = pv;
}
else
{
pv->get_next( at_front );
at_front = pv;
}
add_size();
}
template<typename elemtype>
void list<elemtype>::insert_end( const elemtype iva )
{
if( at_end == NULL)
{
at_end = at_front =
new list_ITem<elemtype>( iva, 0 );
}
else
at_end = new list_ITem<elemtype>( iva, at_end );
add_size();
}
template<typename elemtype> void list<elemtype>::
insert( const elemtype ixa, const elemtype iva )
{
list_ITem<elemtype> *pev =
( list_ITem<elemtype>* )find( iva );
if( pev == NULL )
{
cerr << "err!" <<endl;
return;
}
if( pev == at_front )
insert_front( ixa );
else {
new list_ITem<elemtype>( ixa, pev );
add_size();
}
}
template<typename elemtype> const
list_ITem<elemtype>* list<elemtype>::
find( const elemtype iva )
{
list_ITem<elemtype> *at_move = at_front;
while( at_move != NULL )
{
if( at_move->date() == iva )
return at_move;
at_move = ( list_ITem<elemtype>* )at_move->next();
}
return NULL;
}
template<typename elemtype>
void list<elemtype>::remove_front()
{
if( at_front )
{
list_ITem<elemtype> *pev = at_front;
at_front = ( list_ITem<elemtype>* )at_front->next();
delete pev;
down_size();
}
}
template<typename elemtype>
void list<elemtype>::remove( elemtype iva )
{
list_ITem<elemtype> *pev = at_front;
while( pev && pev->date() == iva )
{
pev = ( list_ITem<elemtype>* )pev->next();
remove_front();
}
if( !pev )
return ;
list_ITem<elemtype> *prv = pev;
pev = ( list_ITem<elemtype>* )pev->next();
while( pev )
{
if( pev->date() == iva )
{
prv->get_next( pev->next() );
down_size();
delete pev;
pev = ( list_ITem<elemtype>* )prv->next();
if( pev != NULL )
{
at_end = prv;
return;
}
}
else
{
prv = pev;
pev = ( list_ITem<elemtype>* )pev->next();
}
}
}
template<typename elemtype>
void list<elemtype>::remove_all()
{
while( at_front )
remove_front();
_size = 0;
at_front = at_end = NULL;
}
template<typename elemtype>
void list<elemtype>::print() const
{
list_ITem<elemtype> *pev = at_front;
cout << '[' << size() << ']';
cout << '{';
for( int ix = 0; pev && ix < size(); ++ix )
{
cout << pev->date() << ' ';
pev = ( list_ITem<elemtype>* )pev->next();
}
cout << '}' << endl;
}
#endif
//下面是出错信息
------------------Configuration: 链表 - Win32 Debug--------------------
Compiling...
链表.cpp
C:\Documents and Settings\Administrator\链表.cpp(22) : error C2143: syntax error : missing ';' before '<'
C:\Documents and Settings\Administrator\链表.cpp(22) : error C2501: 'list_item' : missing storage-class or type specifiers
C:\Documents and Settings\Administrator\链表.cpp(22) : error C2059: syntax error : ';'
C:\Documents and Settings\Administrator\链表.cpp(22) : error C2143: syntax error : missing ';' before '<'
C:\Documents and Settings\Administrator\链表.cpp(22) : error C2065: 'elemtype' : undeclared identifier
C:\Documents and Settings\Administrator\链表.cpp(36) : error C2143: syntax error : missing ';' before '{'
C:\Documents and Settings\Administrator\链表.cpp(36) : error C2447: missing function header (old-style formal list?)
C:\Documents and Settings\Administrator\链表.cpp(39) : error C2954: template definitions cannot nest
C:\Documents and Settings\Administrator\链表.cpp(40) : error C2143: syntax error : missing ';' before '<'
C:\Documents and Settings\Administrator\链表.cpp(40) : error C2734: 'list_item' : const object must be initialized if not extern
C:\Documents and Settings\Administrator\链表.cpp(40) : error C2734: 'list_item' : const object must be initialized if not extern
C:\Documents and Settings\Administrator\链表.cpp(40) : error C2373: 'list_item' : redefinition; different type modifiers
C:\Documents and Settings\Administrator\链表.cpp(22) : see declaration of 'list_item'
C:\Documents and Settings\Administrator\链表.cpp(40) : error C2059: syntax error : ';'
C:\Documents and Settings\Administrator\链表.cpp(40) : error C2143: syntax error : missing ';' before '<'
C:\Documents and Settings\Administrator\链表.cpp(46) : error C2143: syntax error : missing ';' before '{'
C:\Documents and Settings\Administrator\链表.cpp(46) : error C2447: missing function header (old-style formal list?)
C:\Documents and Settings\Administrator\链表.cpp(49) : error C2954: template definitions cannot nest
Error executing cl.exe.
链表.exe - 17 error(s), 0 warning(s)
//环境:windows sp3
vc++ 6.0 sp6 英文版