转贴:STL之list之用法小结

/*
转贴:STL之list之用法小结list: 等同于双向链表,内存空间可以是不连续的,通过指针来进行数据的访问
转贴:STL之list之用法小结   优: 1)插入/删除效率高
转贴:STL之list之用法小结   缺: 1)不支持随机存取,查询效率较低
转贴:STL之list之用法小结
*/

转贴:STL之list之用法小结#include 
<iostream>
转贴:STL之list之用法小结#include 
<string>
转贴:STL之list之用法小结#include 
<list>
转贴:STL之list之用法小结
using namespace std;
转贴:STL之list之用法小结
转贴:STL之list之用法小结
void printList(list<int> nList)
转贴:STL之list之用法小结
{
转贴:STL之list之用法小结//使用迭代器
转贴:STL之list之用法小结
//list<int>::iterator iter;
转贴:STL之list之用法小结
//for ( iter = nList.begin(); iter != nList.end(); iter++)
转贴:STL之list之用法小结
//{
转贴:STL之list之用法小结
// cout<<*iter<<", ";
转贴:STL之list之用法小结
//}
转贴:STL之list之用法小结
转贴:STL之list之用法小结
//使用迭代器指针
转贴:STL之list之用法小结
list<int>::iterator *pIter = new list<int>::iterator; //list<int>::iterator *pIter;error,原因见vector相应函数
转贴:STL之list之用法小结
if ( NULL == pIter )
转贴:STL之list之用法小结{
转贴:STL之list之用法小结   return;
转贴:STL之list之用法小结}

转贴:STL之list之用法小结for (*pIter = nList.begin(); *pIter != nList.end(); (*pIter)++) //此处不可写成*pIter++
转贴:STL之list之用法小结
{
转贴:STL之list之用法小结   cout<<**pIter<<", ";
转贴:STL之list之用法小结}

转贴:STL之list之用法小结cout<<endl;
转贴:STL之list之用法小结}

转贴:STL之list之用法小结
int main()
转贴:STL之list之用法小结
{
转贴:STL之list之用法小结//创建list
转贴:STL之list之用法小结
list<int> l1; //创建一个没有任何元素的list
转贴:STL之list之用法小结
list<int> l2(10); //创建一个有n个元素的list,每个元素值为默认
转贴:STL之list之用法小结
list<double> l3(10, 9.3); //创建具有10个元素的list,每个元素的初始值为9.3
转贴:STL之list之用法小结
list<double> l4(l3); //通过拷贝一个list对象的元素,创建一个新的list对象
转贴:STL之list之用法小结
int iArray[] ={3, 10, 19};
转贴:STL之list之用法小结list<int> l5(iArray, iArray + 3);//将另一个list对象的迭代器区间[first, last)所指的元素,拷贝到新创建的list对象中
转贴:STL之list之用法小结
转贴:STL之list之用法小结
//初如化赋值 :用push_back将元素依次链入LIST中
转贴:STL之list之用法小结
for (int i = 1; i<6; i++)
转贴:STL之list之用法小结   l1.push_back(i);
转贴:STL之list之用法小结
转贴:STL之list之用法小结list<int>::iterator iter;
转贴:STL之list之用法小结cout<<"printList(l1): "<<endl;
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结//元素插入 :尾部添加用push_back(); 首部插入用push_front();任意位置插入用insert(&pos, elem) 
转贴:STL之list之用法小结
//下面语句error:list与vector不同,因为存储方式上的差异, list不能+n,只能++,
转贴:STL之list之用法小结
//这种情况下最好还是通过迭代器++为好
转贴:STL之list之用法小结
//l1.insert((l1.begin())+1, 100); 
转贴:STL之list之用法小结
l1.insert(++l1.begin(), 100); //或者用iter=l1.begin(); iter++;l1.insert(iter, 100);
转贴:STL之list之用法小结
cout<<"++l1.insert(l1.begin(),100) (if use l1.begin()+1 is error) = "<<endl;
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结cout<<"l1.push_back(200) = "<<endl;
转贴:STL之list之用法小结l1.push_back(200);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结cout<<"l1.push_front(-200) = "<<endl;
转贴:STL之list之用法小结l1.push_front(-200);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结//元素删除: 尾部删除用pop_back(); 首部删除用pop_front(); 
转贴:STL之list之用法小结
//指定元素的删除,位置用erase(&pos); 区间用erase(&first_pos, &last_pos)
转贴:STL之list之用法小结
//删除所有元素用 clear(); 
转贴:STL之list之用法小结
//删除list中所有元素值为value的元素用remove(value)
转贴:STL之list之用法小结
cout<<"l1.pop_back() = "<<endl;
转贴:STL之list之用法小结l1.pop_back();
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结cout<<"l1.pop_front() = "<<endl;
转贴:STL之list之用法小结l1.pop_front();
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结cout<<"l1.erase(++l1.begin()) = "<<endl;
转贴:STL之list之用法小结l1.erase(++l1.begin());
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结iter= l1.begin();
转贴:STL之list之用法小结iter++;
转贴:STL之list之用法小结iter++;
转贴:STL之list之用法小结cout<<"iter=l1.begin; iter++;iter++; l1.erase(l1.begin(), iter) = "<<endl;
转贴:STL之list之用法小结l1.erase(l1.begin(), iter);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结cout<<"l1.remove(100) = "<<endl;
转贴:STL之list之用法小结l1.remove(100);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结cout<<"l1.remove(4) = "<<endl;
转贴:STL之list之用法小结l1.remove(4);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结//其它
转贴:STL之list之用法小结
cout<<"其它: "<<endl;
转贴:STL之list之用法小结list<int> listTest;
转贴:STL之list之用法小结for (int i =1; i<6; i++)
转贴:STL之list之用法小结   listTest.push_back(i*100);
转贴:STL之list之用法小结cout<<"printList(listTest) = "<<endl;
转贴:STL之list之用法小结printList(listTest);
转贴:STL之list之用法小结//swap函数
转贴:STL之list之用法小结
cout<<"after l1.swap(listTest), l1 = "<<endl;
转贴:STL之list之用法小结l1.swap(listTest);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结//splice函数 
转贴:STL之list之用法小结
//void splice(&pos, list &x):将list x归并到当前list的&pos之前,同时list x将被清空
转贴:STL之list之用法小结
//void splice(&pos, list &x, &x.pos),将list x中迭代器x.pos处的元素归并到当前list,同时被归并的元素将被清空
转贴:STL之list之用法小结
cout<<"after l1.splice(l1.begin(), listTest):"<<endl;
转贴:STL之list之用法小结l1.swap(listTest); //恢复
转贴:STL之list之用法小结
l1.splice(l1.begin(), listTest);
转贴:STL之list之用法小结cout<<"l1 = "<<endl;
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结cout<<"listTest = "<<endl;
转贴:STL之list之用法小结printList(listTest);
转贴:STL之list之用法小结
转贴:STL之list之用法小结l1.clear();
转贴:STL之list之用法小结for (int i = 1; i<6; i++)
转贴:STL之list之用法小结   l1.push_back(i);
转贴:STL之list之用法小结for (int i =1; i<6; i++)
转贴:STL之list之用法小结   listTest.push_back(i*100); //恢复
转贴:STL之list之用法小结
cout<<"after l1.splice(++l1.begin(), listTest, --listTest.end()) :"<<endl;
转贴:STL之list之用法小结l1.splice(++l1.begin(), listTest, --listTest.end());
转贴:STL之list之用法小结cout<<"l1 = "<<endl;
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结cout<<"listTest = "<<endl;
转贴:STL之list之用法小结printList(listTest);
转贴:STL之list之用法小结
转贴:STL之list之用法小结//merge函数(略)归并的两链表都是是有序性,此函数才有意义
转贴:STL之list之用法小结
//sort
转贴:STL之list之用法小结
cout<<"now l1 is set as : "<<endl;
转贴:STL之list之用法小结l1.clear();
转贴:STL之list之用法小结for (int i = 9; i >= 0; i--)
转贴:STL之list之用法小结   l1.push_back(i);
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结cout<<"l1.sort() = "<<endl;
转贴:STL之list之用法小结l1.sort();
转贴:STL之list之用法小结printList(l1);
转贴:STL之list之用法小结
转贴:STL之list之用法小结cout<<"l1.empty() = "<<l1.empty()<<", l1.size() = "<<l1.size()<<endl;
转贴:STL之list之用法小结cout<<"after l1.clear(): "<<endl;
转贴:STL之list之用法小结l1.clear();
转贴:STL之list之用法小结cout<<"l1.empty() = "<<l1.empty()<<", l1.size() = "<<l1.size()<<endl;
转贴:STL之list之用法小结}

转贴:STL之list之用法小结
转贴:STL之list之用法小结
转贴:STL之list之用法小结
转贴:STL之list之用法小结
//测试结果
转贴:STL之list之用法小结
printList(l1):
转贴:STL之list之用法小结
12345,
转贴:STL之list之用法小结
++l1.insert(l1.begin(),100) (if use l1.begin()+1 is error
转贴:STL之list之用法小结
11002345,
转贴:STL之list之用法小结l1.push_back(
200=
转贴:STL之list之用法小结
11002345200,
转贴:STL之list之用法小结l1.push_front(
-200=
转贴:STL之list之用法小结
-20011002345200,
转贴:STL之list之用法小结l1.pop_back() 
=
转贴:STL之list之用法小结
-20011002345,
转贴:STL之list之用法小结l1.pop_front() 
=
转贴:STL之list之用法小结
11002345,
转贴:STL之list之用法小结l1.erase(
++l1.begin()) =
转贴:STL之list之用法小结
12345,
转贴:STL之list之用法小结iter
=l1.begin; iter++;iter++; l1.erase(l1.begin(), iter)
转贴:STL之list之用法小结
345,
转贴:STL之list之用法小结l1.remove(
100=
转贴:STL之list之用法小结
345,
转贴:STL之list之用法小结l1.remove(
4=
转贴:STL之list之用法小结
35,
转贴:STL之list之用法小结其它:
转贴:STL之list之用法小结printList(listTest) 
=
转贴:STL之list之用法小结
100200300400500,
转贴:STL之list之用法小结after l1.swap(listTest), l1 
=
转贴:STL之list之用法小结
100200300400500,
转贴:STL之list之用法小结after l1.splice(l1.begin(), listTest):
转贴:STL之list之用法小结l1 
=
转贴:STL之list之用法小结
10020030040050035,
转贴:STL之list之用法小结listTest 
=
转贴:STL之list之用法小结
转贴:STL之list之用法小结after l1.splice(
++l1.begin(), listTest, --listTest.end())
转贴:STL之list之用法小结l1 
=
转贴:STL之list之用法小结
15002345,
转贴:STL之list之用法小结listTest 
=
转贴:STL之list之用法小结
100200300400,
转贴:STL之list之用法小结now l1 
is set as :
转贴:STL之list之用法小结
9876543210,
转贴:STL之list之用法小结l1.sort() 
=
转贴:STL之list之用法小结
0123456789,
转贴:STL之list之用法小结l1.empty() 
= 0, l1.size() = 10
转贴:STL之list之用法小结after l1.clear():
转贴:STL之list之用法小结l1.empty() 
= 1, l1.size() = 0
转贴:STL之list之用法小结
上一篇:关于ora-02391问题的总结


下一篇:Oracle的优化器(Optimizer)