CList类的使用.docx

上传人:b****5 文档编号:8509016 上传时间:2023-01-31 格式:DOCX 页数:8 大小:15.77KB
下载 相关 举报
CList类的使用.docx_第1页
第1页 / 共8页
CList类的使用.docx_第2页
第2页 / 共8页
CList类的使用.docx_第3页
第3页 / 共8页
CList类的使用.docx_第4页
第4页 / 共8页
CList类的使用.docx_第5页
第5页 / 共8页
点击查看更多>>
下载资源
资源描述

CList类的使用.docx

《CList类的使用.docx》由会员分享,可在线阅读,更多相关《CList类的使用.docx(8页珍藏版)》请在冰豆网上搜索。

CList类的使用.docx

CList类的使用

链表类CList成员的使用

链表类CList成员的使用

使用时要

#include

Construction

CList

Constructsanemptyorderedlist.

建立一个链表

example:

CListmyList;//建立一个int链表

CListmyList(16);//建立一个cstring的链表,后面的16表示链表里面数据的个数,如果不写的话,可能是不限个数?

CListmyList;//建立一个MYTYPE类型(自定义)的链表

如果不存入数据的话,刚建立的链表是空的,头尾都为空

Head/TailAccess

GetHead

Returnstheheadelementofthelist(cannotbeempty).

返回链表的头数据

例子:

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

inttmp=myList.GetHead();//tmp被赋予了0

GetTail

Returnsthetailelementofthelist(cannotbeempty).

返回链表的尾数据

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

inttmp=myList.GetTail();//tmp被赋予了9999

Operations

RemoveHead

Removestheelementfromtheheadofthelist.

移除链表头数据,链表数据个数减1,返回缩减前的头数据

例子:

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

inttmp=myList.RemoveHead();//tmp被赋予了之前的头数据:

0;同时数据个数变为9999;

RemoveTail

Removestheelementfromthetailofthelist.

移除链表尾数据,链表数据个数减1,返回缩减前的尾数据

例子:

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

inttmp=myList.RemoveTail();//tmp被赋予了之前的尾数据:

9999;同时数据个数变为9999;

AddHead

Addsanelement(oralltheelementsinanotherlist)totheheadofthelist(makesanewhead).

在链表头处插入新数据,链表数据个数加1,返回新的链表头位置(POSITION);

例子:

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.AddHead(int(314));//链表有了一个新的头数据:

314;同时链表个数变为10001;pos为新的头的位置;

AddTail

Addsanelement(oralltheelementsinanotherlist)tothetailofthelist(makesanewtail).

在链表尾处插入新数据,链表数据个数加1,返回新的链表尾位置(POSITION);

例子:

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.AddTail(int(314));//链表有了一个新的尾数据:

314;同时链表个数变为10001;pos为新的尾的位置;

RemoveAll

Removesalltheelementsfromthislist.

清空链表,其头尾皆变成空指针;

Iteration

GetHeadPosition

Returnsthepositionoftheheadelementofthelist.

返回链表头的位置;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetHeadPosition();//获得链表头的位置

GetTailPosition

Returnsthepositionofthetailelementofthelist.

返回链表尾的位置;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetTailPosition();//获得链表尾的位置

GetNext

Getsthenextelementforiterating.

返回当前位置的数据,之后,位置后移一位;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetHeadPosition();//获得链表头的位置

inttmp=myList.GetNext(pos);//tmp被赋予了头数据的值:

0;同时pos指向第二个数据1;

GetPrev

Getsthepreviouselementforiterating.

返回当前位置的数据,之后,位置前移一位;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetTailPosition();//获得链表尾的位置

inttmp=myList.GetNext(pos);//tmp被赋予了尾巴数据的值:

9999;同时pos指向倒数第二个数据9998;

Retrieval/Modification

GetAt

Getstheelementatagivenposition.

返回指定位置的数据;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetTailPosition();//获得链表尾的位置,还可以继续改变pos,以指向其他数据

inttmp=myList.GetAt(pos);//tmp被赋予链表尾的数据

SetAt

Setstheelementatagivenposition.

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetTailPosition();//获得链表尾的位置,还可以继续改变pos,以指向其他数据

myList.SetAt(pos,int(222));//将链表尾部的数据赋成222

RemoveAt

Removesanelementfromthislist,specifiedbyposition.

清除指定位置处的数据;同时数据个数减1;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetTailPosition();//获得链表尾的位置

myList.RemoveAt(pos);//链表pos(尾部)位置的数据被清除,数据个数变为9999;

Insertion

InsertBefore

Insertsanewelementbeforeagivenposition.

在指定位置前插入一个新数据,数据个数加1;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetHeadPosition();//获得第一个数据的位置

myList.InsertBefore(pos,int(123));//在第一个数据前插入一个新数据:

123,同时数据个数变为10001

InsertAfter

Insertsanewelementafteragivenposition.

在指定位置后插入一个新数据,数据个数加1;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.GetHeadPosition();//获得第一个数据的位置

myList.InsertAfter(pos,int(123));//在第一个数据后插入一个新数据:

123,同时数据个数变为10001

Searching

Find

Getsthepositionofanelementspecifiedbypointervalue.

返回指定数据对应的位置;

CListmyList;

for(inti=0;i<10000;i++){myList.AddTail(int(i));}//存入数据

POSITIONpos=myList.Find(int(0));//获得0(链表头)的位置

FindIndex

Getsthepositionofanelementspecifiedbyazero-basedindex.

返回索引号对应的位置;

POSITIONpos=myList.FindIndex(0);//0表示链表头,以此类推

Status

GetCount

Returnsthenumberofelementsinthislist.

返回链表的数据个数

intnum=myList.GetCount();//获得链表的数据个数

IsEmpty

Testsfortheemptylistcondition(noelements).

判定链表是否为空;

返回1表示链表是空,返回0表示链表非空;

BOOLempty=myList.IsEmpty();

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 院校资料

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1