C++List模板类的使用

来源:互联网 发布:男主换脸的网络电影 编辑:程序博客网 时间:2024/05/16 19:08

List的使用

在使用list必须包括头文件#include <list>

如何定义一个list对象

[cpp] view plain copy
  1. #include <list>  
  2. int main (void)  
  3. {  
  4.     list<char > cList; //声明了list<char>模板类 的一个实例  
  5. }  

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

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

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

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

[cpp] view plain copy
  1. if (cList.empty())  
  2. {  
  3.     printf(“this list is empty”);  
  4. }  


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

[cpp] view plain copy
  1. list< char>::iterator charIterator;  
  2. for(cIterator = cList.Begin();cIterator != cList.end();cIterator++)  
  3. {  
  4.     printf(“%c”, *cIterator);  
  5. //输出list中的所有对象  

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

用STL的通用算法count()来统计list中的元素个数

int cNum;

char ch = ’b’;

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

说明:在使用count()函数之前必须加入#include <algorithm>

用STL的通用算法count_if ()来统计list中的元素个数

[cpp] view plain copy
  1. const char c(‘c’);  
  2. class IsC  
  3. {  
  4. public:  
  5.     bool operator() ( char& ch )  
  6.     {  
  7.         return ch== c;  
  8.     }  
  9. };  
  10.   
  11. int numC;  
  12. numC = count_if (cList.begin(), cList.end(),IsC());//统计c的数量;  

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

使用STL通用算法find()在list中查找对象

[cpp] view plain copy
  1. list<char >::iterator FindIterator;  
  2. FindIterator = find(cList.begin(), cList.end(), ‘c’);  
  3. If (FindIterator == cList.end())  
  4. {  
  5.     printf(“not find the char ‘c’!”);  
  6. }  
  7. else  
  8. {  
  9.     printf(“%c”, * FindIterator);  
  10. }  

说明:如果没有找到指定的对象,就会返回cList.end()的值,找到了就返回一个指向对象iterator的指针。

使用STL通用算法find_if()在list中查找对象

[cpp] view plain copy
  1. const char c(‘c’);  
  2. class c  
  3. {  
  4. public:  
  5.     bool operator() ( char& ch )  
  6.     {  
  7.         return ch== c;  
  8.     }  
  9. };  
  10.   
  11. list<char>::iterator FindIterator  
  12. FindIterator = find_if (cList.begin(), cList.end(),IsC());//查找字符串c;  

说明:如果没有找到指定的对象,就会返回cList.end()的值,找到了就返回一个指向对象iterator的指针。

使用list的成员函数sort()排序

cList.sort();

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

[cpp] view plain copy
  1. cList.insert(cLiset.end, ‘c’); ///在list末尾插入字符‘c’  
  2.   
  3. char ch[3] ={‘a’, ‘b’, ‘c’};  
  4. cList.insert(cList.end, &ch[0], & ch[3] ); //插入三个字符到list中  
  5. 说明:insert()函数把一个或多个元素插入到指出的iterator位置。元素将出现在 iterator指出的位置以前。  
  6. 如何在list中删除元素  
  7. cList.pop_front(); //删除第一个元素  
  8. cList.pop_back(); //删除最后一个元素  
  9. cList. Erase(cList.begin()); //使用iterator删除第一个元素;  
  10. cList. Erase(cList.begin(), cList.End()); //使用iterator删除所有元素;  
  11. cList.remove(‘c’); //使用remove函数删除指定的对象;  
  12.   
  13. list<char>::iterator newEnd;  
  14. //删除所有的’c’ ,并返回指向新的list的结尾的iterator  
  15. newEnd = cList.remove(cList.begin(), cList.end(), ‘c’);  
0 0
原创粉丝点击