c++中的list用法

请问C++中list的具体用法
比如说list是干什么用的,常用的格式是什么,这种格式能起到什么效果.特别是如list<T>啊,iterator的用法

#include <iostream>
#include <list>
#include <numeric>
#include <algorithm>

using namespace std;

//创建一个list容器的实例LISTINT
typedef list<int> LISTINT;

//创建一个list容器的实例LISTCHAR
typedef list<int> LISTCHAR;

void main(void)
{
//--------------------------
//用list容器处理整型数据
//--------------------------
//用LISTINT创建一个名为listOne的list对象
LISTINT listOne;
//声明i为迭代器
LISTINT::iterator i;

//从前面向listOne容器中添加数据
listOne.push_front (2);
listOne.push_front (1);

//从后面向listOne容器中添加数据
listOne.push_back (3);
listOne.push_back (4);

//从前向后显示listOne中的数据
cout<<"listOne.begin()--- listOne.end():"<<endl;
for (i = listOne.begin(); i != listOne.end(); ++i)
cout << *i << " ";
cout << endl;

//从后向后显示listOne中的数据
LISTINT::reverse_iterator ir;
cout<<"listOne.rbegin()---listOne.rend():"<<endl;
for (ir =listOne.rbegin(); ir!=listOne.rend();ir++) {
cout << *ir << " ";
}
cout << endl;

//使用STL的accumulate(累加)算法
int result = accumulate(listOne.begin(), listOne.end(),0);
cout<<"Sum="<<result<<endl;
cout<<"------------------"<<endl;

//--------------------------
//用list容器处理字符型数据
//--------------------------

//用LISTCHAR创建一个名为listOne的list对象
LISTCHAR listTwo;
//声明i为迭代器
LISTCHAR::iterator j;

//从前面向listTwo容器中添加数据
listTwo.push_front ('A');
listTwo.push_front ('B');

//从后面向listTwo容器中添加数据
listTwo.push_back ('x');
listTwo.push_back ('y');

//从前向后显示listTwo中的数据
cout<<"listTwo.begin()---listTwo.end():"<<endl;
for (j = listTwo.begin(); j != listTwo.end(); ++j)
cout << char(*j) << " ";
cout << endl;

//使用STL的max_element算法求listTwo中的最大元素并显示
j=max_element(listTwo.begin(),listTwo.end());
cout << "The maximum element in listTwo is: "<<char(*j)<<endl;
}

#include <iostream>
#include <list>

using namespace std;
typedef list<int> INTLIST;

//从前向后显示list队列的全部元素
void put_list(INTLIST list, char *name)
{
INTLIST::iterator plist;

cout << "The contents of " << name << " : ";
for(plist = list.begin(); plist != list.end(); plist++)
cout << *plist << " ";
cout<<endl;
}

//测试list容器的功能
void main(void)
{
//list1对象初始为空
INTLIST list1;
//list2对象最初有10个值为6的元素
INTLIST list2(10,6);
//list3对象最初有3个值为6的元素
INTLIST list3(list2.begin(),--list2.end());

//声明一个名为i的双向迭代器
INTLIST::iterator i;

//从前向后显示各list对象的元素
put_list(list1,"list1");
put_list(list2,"list2");
put_list(list3,"list3");

//从list1序列后面添加两个元素
list1.push_back(2);
list1.push_back(4);
cout<<"list1.push_back(2) and list1.push_back(4):"<<endl;
put_list(list1,"list1");

//从list1序列前面添加两个元素
list1.push_front(5);
list1.push_front(7);
cout<<"list1.push_front(5) and list1.push_front(7):"<<endl;
put_list(list1,"list1");

//在list1序列中间插入数据
list1.insert(++list1.begin(),3,9);
cout<<"list1.insert(list1.begin()+1,3,9):"<<endl;
put_list(list1,"list1");

//测试引用类函数
cout<<"list1.front()="<<list1.front()<<endl;
cout<<"list1.back()="<<list1.back()<<endl;

//从list1序列的前后各移去一个元素
list1.pop_front();
list1.pop_back();
cout<<"list1.pop_front() and list1.pop_back():"<<endl;
put_list(list1,"list1");

//清除list1中的第2个元素
list1.erase(++list1.begin());
cout<<"list1.erase(++list1.begin()):"<<endl;
put_list(list1,"list1");

//对list2赋值并显示
list2.assign(8,1);
cout<<"list2.assign(8,1):"<<endl;
put_list(list2,"list2");

//显示序列的状态信息
cout<<"list1.max_size(): "<<list1.max_size()<<endl;
cout<<"list1.size(): "<<list1.size()<<endl;
cout<<"list1.empty(): "<<list1.empty()<<endl;

//list序列容器的运算
put_list(list1,"list1");
put_list(list3,"list3");
cout<<"list1>list3: "<<(list1>list3)<<endl;
cout<<"list1<list3: "<<(list1<list3)<<endl;

//对list1容器排序
list1.sort();
put_list(list1,"list1");

//结合处理
list1.splice(++list1.begin(), list3);
put_list(list1,"list1");
put_list(list3,"list3");
}

参考:http://hi.baidu.com/xun1573/blog/item/6b6a2f087ebbe9960b7b8249.html
温馨提示:内容为网友见解,仅供参考
第1个回答  2015-09-15
1.定义一个list
定义一个STL的list:
#include <string>
#include <list>
int main (void)
{
list<string> Milkshakes;
return 0;
}
2.
这就行了,已经定义了一个list。list<string>
Milkshakes这句是声明list<string>模板类
的一个实例,然后就是实例化这个类的一个对象。在这一步需要知道定义了 一个字符串的list。包含提供STL
list类的头文件。Linux上编译这个测试程序,例如:
g++ test1.cpp -o test1
注意iostream.h这个头文件已经被STL的头文件放弃了。这就是为什么这个例子中没有它的原因。

3.现在有了一个list,把一个字符串加到这个list里。有一个非常
重要的东西叫做list的值类型。值类型就是list中的对象的类型。在这个例子中,这个list的值类型就是字符串,string ,
这是因为这个list用来放字符串。
4.使用list的成员函数push_back和push_front插入一个元素到list中
#include <string>
#include <list>

int main (void)
{
list<string> Milkshakes;
Milkshakes.push_back("Chocolate");
Milkshakes.push_back("Strawberry");
Milkshakes.push_front("Lime");
Milkshakes.push_front("Vanilla");
return 0;
}
5.现在有个4个字符串在list中。list的成员函数push_back()把一个对象放到一个list的后面,而
push_front()把对象放到前面。我通常把一些错误信息push_back()到一个list中去,然后push_front()一个标题到
list中。
第2个回答  2008-02-21
list<类型> 变量名
list<int> a;
a.insert(5);
a.insert(89);
第3个回答  2008-02-21
list(链表)是标准STL序列容器 ,
关于STL,网上搜索吧

C++ 如何使用 std::list 容器
myList.remove_first(); \/\/ 移除第一个元素 myList.clear(); \/\/ 清空容器 bool isEmpty = myList.empty(); \/\/ 检查是否为空 std::list在需要动态增删元素的场景中非常实用,是C++标准库中一种灵活的数据结构。希望这些基本操作能帮助您更好地理解和使用std::list。

C++语法糖(initializer_list)详解以及示例代码
initializer_list是C++11引入的一种语法糖,用于创建由多个值组成的列表,类似于Python列表或JavaScript数组,简化了数组、容器初始化与作为函数参数传递的过程。下面实例展示如何利用initializer_list创建包含多个整数的列表,并传递给函数进行处理:定义一个名为print_ints的函数,接受一个initializer_list类型的...

c++中list链表如何实现输出指定位置的值
你好,list 底层是一个链表, 是用指针实现的,所以不能向数组那样直接得到,你可以自己写一个来遍历, 如;template<typename T>T get_value(list<T> ls, int index) { typename list<T>::iterator iter; iter = ls.begin(); for(int i = 0; i < index; ++i) { iter++; }...

C++中list容器怎么随机访问其中元素
list 不是顺序放在内存里的,一定要遍历一次;list<int>::iterator iter=a.begin();int n;\/\/n是要访问的第n+1个元素,譬如0是第1个元素 for(int ix=0; ix<n; ++ix) ++iter;iter;\/\/就是第n+1个元素的内容

C++ STL std::list部分实现
常用方法begin和end方法根据哨兵结点的指向来确定链表的开始和结束,当list为空时,这些方法的实现有所不同。其他常见的成员函数如push_back和insert,主要是通过双向链表的指针操作来完成的,这里不再详述。总的来说,理解list的这些核心概念和操作,你就可以在需要时自如地使用std::list了。

C++ list容器,不用迭代器如何输出元素?
1、可以用.front()方法和.pop_front()方法遍历list容器,同时不适用迭代器。2、例程:include<iostream>using namespace std;#include<list>void main(){ list<int> ilist; for(int ix=0;ix!=4;++ix) ilist.push_back(ix); for(ix=0;ix!=4;++ix) { cout<<ilist.f...

c++中怎么确定list 容器里的元素的位置 求高手解答 在线等答案_百度知 ...
使用find啊,list是一个链表,所以不能用下标来标识。只能通过迭代器来获取位置。两种方式,一种是调用list的find算法 list<XX>::iterator it = LIST.find(value);这里的it就是元素的位置。如果你要计数也可以,通过for循环查找,得到位置。list<XX>::iterator it = LIST.begin();int i = 0;for...

C++ 如何删除list集合前面n条元素?
可以使用如下方法:list.erase(list.begin(), list.begin() + n)该方法比自己写循环语句效率要高,另外自己写循环语句需要注意迭代器的正确性

C++ list输出具体第几项
list 不能随机读取,就是不能用下标。只能用迭代器。list<int> a={2,3,4,5};list<int>::iterator it=++a.begin();cout<<*it;

C++ vector和list的区别
C++编程语言中,vector与list是两种常用的数据结构。它们在实现上和使用场景上有明显的区别,理解这些差异将有助于你更高效地运用C++进行程序开发。首先,vector和list都是模板类,支持动态数组功能,但它们在内存管理和操作效率上有显著差异。vector是连续存储元素,提供快速随机访问,适用于频繁读取元素的场景...

相似回答