STL系列之list的常见功能使用

STL系列之list的常见功能使用

list是一个双向循环链表,双链表既可以向前又可以向后链接它的元素。

list将元素按顺序储存在链表中. 与向量(vector)相比, 它允许快速的插入和删除,但是随机访问却比较慢。

1)、如何定义一个list对象

#include<list>//在使用list时必须包含头文件#include <list>

intmain (void)

{

 list<char> cList; //声明了list<char>模板类的一个实例

}

2)、使用list的成员函数push_back和push_front插入一个元素到list中

cList.push_back(‘a’); //把一个对象放到一个list的后面

cList.push_front (‘b’); //把一个对象放到一个list的前面

3)、使用list的成员函数empty()判断list是否为空

if(cList.empty())

{

 printf(“this list is empty”);

}

4)、用list< char >::iterator得到指向list的指针

list<char>::iterator charIterator;

for(cIterator= cList.Begin();cIterator != cList.end();cIterator++)

{

 printf(“%c”, *cIterator);

}//输出list中的所有对象

说明:cList.Begin()和cList.end()函数返回指向list< char >::iterator的指针,由于list采用链表结构,因此它不支持随机存取,因此不能用cList.begin()+3来指向list中的第四个对象,vector和deque支持随机存取。
5)、用STL的通用算法count()来统计list中的元素个数

intcNum;

charch = ’b’;

cNum= count(cList.Begin(), cList.end(), ch); //统计list中的字符b的个数

说明:在使用count()函数之前必须加入#include <algorithm> 
6)、用STL的通用算法count_if()来统计list中的元素个数

constchar c(‘c’);

classIsC

{

public:

 bool operator() ( char& ch )

 {

  return ch== c;

 }

};

 

intnumC;

numC= count_if (cList.begin(), cList.end(),IsC());//统计c的数量

说明:count_if()带一个函数对象的参数,函数对象是一个至少带有一个operator()方法的类函数对象被约定为STL算法调用operator时返回true或false。它们根据这个来判定这个函数。举个例子会 说的更清楚些。count_if()通过传递一个函数对象来作出比count()更加复杂的评估以确定一个对象是否应该被记数。
7)、使用STL通用算法find()在list中查找对象

list<char>::iterator FindIterator;

FindIterator= find(cList.begin(), cList.end(), ‘c’);

if(FindIterator == cList.end())

{

 printf(“not find the char ‘c’!”);

}

else

{

 printf(“%c”, * FindIterator);

}

说明:如果没有找到指定的对象,就会返回cList.end()的值,找到了就返回一个指向对象iterator的指针。
8)、使用STL通用算法find_if()在list中查找对象

constchar c(‘c’);

classc

{

public:

 bool operator() ( char& ch )

 {

  return ch== c;

 }

};

 

list<char>::iteratorFindIterator

FindIterator= find_if (cList.begin(), cList.end(),IsC());//查找字符串c

说明:如果没有找到指定的对象,就会返回cList.end()的值,找到了就返回一个指向对象iterator的指针。
9)、使用list的成员函数sort()排序

cList.sort();

10)、使用list的成员函数insert插入一个对象到list中

cList.insert(cLiset.end,‘c’); ///list末尾插入字符‘c’

charch[3] ={‘a’, ‘b’, ‘c’};

cList.insert(cList.end,&ch[0], & ch[3] ); //插入三个字符到list

说明:insert()函数把一个或多个元素插入到指出的iterator位置。元素将出现在 iterator指出的位置以前。
11)、如何在list中删除元素

cList.pop_front();//删除第一个元素

cList.pop_back();//删除最后一个元素

cList.Erase(cList.begin()); //使用iterator删除第一个元素;

cList.Erase(cList.begin(), cList.End()); //使用iterator删除所有元素;

cList.remove(‘c’);//使用remove函数删除指定的对象;

list<char>::iteratornewEnd;

newEnd= cList.remove(cList.begin(), cList.end(), ‘c’); //删除所有的’c’ ,并返回指向新的list的结尾的iterator

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值