4196
备注:
|
7238
|
删除的内容标记成这样。 | 加入的内容标记成这样。 |
行号 7: | 行号 7: |
行号 9: | 行号 10: |
除此以外还有: * 特殊的容器:string(字符串), array(C语言原始数组) * 容器适配器:stack(栈), queue(队列), priority_queue(优先队列) |
除此以外还有: * 特殊的容器:string(字符串), array(C语言原始数组) * 容器适配器:stack(栈), queue(队列), priority_queue(优先队列) |
行号 13: | 行号 16: |
行号 17: | 行号 21: |
行号 21: | 行号 26: |
* 输出跌代子 | * 输出跌代子 |
行号 23: | 行号 29: |
行号 34: | 行号 41: |
{{{#!cplusplus | {{{ #!cplusplus |
行号 40: | 行号 49: |
行号 41: | 行号 51: |
行号 42: | 行号 53: |
{{{#!cplusplus | {{{ #!cplusplus |
行号 45: | 行号 57: |
vector < int > a4(a2); //构造一个vector与a2完全一样 | vector< int > a4(a2); //构造一个vector与a2完全一样 |
行号 48: | 行号 60: |
vector < int > a5( values, values+5); //通过迭代子来构造vector | vector< int > a5( values, values+5); //通过迭代子来构造vector |
行号 52: | 行号 64: |
{{{#!cplusplus | {{{ #!cplusplus |
行号 60: | 行号 73: |
行号 61: | 行号 75: |
{{{#!cplusplus | {{{ #!cplusplus |
行号 67: | 行号 82: |
行号 68: | 行号 84: |
{{{#!cplusplus | {{{ #!cplusplus |
行号 74: | 行号 91: |
行号 75: | 行号 93: |
{{{#!cplusplus | {{{ #!cplusplus |
行号 87: | 行号 106: |
== 用法实例 == {{{ #!cplusplus #include <vector> int main() { using namespace std; vector< string > sentence; sentence.reserve( 5 ); sentence.push_back( “ Hello, “); sentence.push_back( “how “); sentence.push_back( “are “); sentence.push_back( "you "); sentence.push_back( “?“); copy( sentence.begin(), sentence.end(), ostream_iterator<string>(cout, “ “)); cout << endl; cout << sentence.size() << endl; cout << sentence.capacity() << endl; swap( sentence[1], sentence[3]); sentence.insert( find(sentence.begin(), sentence.end(), “?”), “always”); sentence.back() = “!”; copy( sentence.rbegin(), sentence.rend(), ostream_iterator<string>(cout, “ “)); cout << endl; } }}} 用vector代替数组使用 {{{ #!cplusplus vector < int > a(10); // int a[10]; a[0] = 1; a[1] = 2; a[2] = a[0] + a[1]; for( int i = 0; i < a.size(); i++) scanf( “%d”, &a[i] ); }}} == vector的实现 == vector的实现类似于数据结构中的顺序表 attachment:vector.jpg {{{#!cplusplus template<class T, class Alloc=alloc> class vector { public: typedef T value_type; typedef value_type* iterator; typedef size_t size_type; protected: iterator start; iterator finish; iterator end_of_storage; //... public: iterator begin() { return start; } iterator end() { return finish; } size_type reserve(size_type n); //改变容量的大小 size_type capacity() const { //返回当前容量的大小 return size_type(end_of_storage - begin()); } void push_back(const T& x) { if(finish != end_of_storage) { construct(finish, x); ++finish; } else { insert_aux(end(), x); } } void insert_aux(iterator position, const T& x) { if(finish != end_of_storage) { construct(finish, *(finish-1)); ++finish; T x_copy = x; copy_backward(position, finish-2, finish-1); *position = x_copy; } else { const size_type old_size = size(); const size_type len = old_size != 0 ? 2 * old_size : 1; iterator new_start = data_allocator::alloate(len); iterator new_finish = new_start; try { new_finish = uninitialized_copy(start, position, new_start); construct(new_finish, x); ++ new_finish; new_finish = uninitialized_copy(position, finish, new_finish); } catch(...) { destroy(new_start, new_finish); data_allocator::deallocate(new_start, len); throw; } destroy(begin(), end()); deallocate(); start = new_start; finish = new_finish; end_of_storage = new_start + len; } } }; }}} |
STL概述
STL是Standard Template Library的缩写,是C++标准库中最强大、最复杂、最有用的部分。STL主要由容器(container)、跌代子(iterator)、算法(algorithm)所组成。还有仿函数(functor)、适配器(adapter)、配置器(allocator)等辅助组件。
1. 容器container
容器是存放和管理数据元素的数据结构,分为两大类:顺序容器(sequence container)和关联容器(associative container)。
- 顺序容器有:vector(向量,酷似数组), deque(双端队列), list(双链表)
- 关联容器有:map(字典), set(集合), multi_map(允许重复键的字典), multi_set(允许重复键的集合)
除此以外还有:
- 特殊的容器:string(字符串), array(C语言原始数组)
- 容器适配器:stack(栈), queue(队列), priority_queue(优先队列)
- 内部容器:不提供给用户使用,只用来实现其他容器,比如红黑树(用来实现map,set),堆(用来实现priority_queue)
容器一般使用模板类来实现
2. 跌代子iterator
跌代子是用来访问容器内元素的对象,类似指针。 跌代子根据能力的不同,分为:
- 随机跌代子(vector、deque的迭代子)
- 双向跌代子(list的迭代子)
- 单向跌代子
- 输入跌代子
- 输出跌代子
另外还有
- 跌代子适配器:将原来不是迭代子的东西变成迭代子,或者将一种迭代子变成另一种迭代子(比如back_inserter, front_inserter, inserter, 反向迭代子,ostream_iterator, istream_iterator)
3. 算法algorithm
算法是用来处理容器内的元素的一些操作,比如搜索、排序、拷贝、修改等。算法一般使用函数模板来实现。
4. 仿函数functor
用法类似函数的对象。用重载了operator()的类或者模板类来实现
vector向量
1. 接口说明
vector的用法类似于数组,不同的是数组空间可以动态分配。
T可以是任何类型,但是必须满足:assignable, copyable
1.1. 构造方法
1.2. 不变操作和赋值
1.3. 元素访问
1.4. 跌代子
1.5. 插入删除操作
1 a1.insert( a1.begin(), 5); //在a1的最前面插入一个5
2 a1.insert(a1.end(), 10, 6); //在a1的最后面插入10个6
3 a1.insert(a1.begin(), values, values+5) //在a1的最前面插入values[0]到values[4]
4 a1.push_back( 5 ) //在a1的最后面插入一个5
5 a1.pop_back( ) // 删除a1的最后一个元素
6 a1.erase( a1.begin() ) //删除a1中的第一个元素
7 a1.erase( a1.begin(), a1.begin() +2) //删除a1最前面2个元素
8 a1.resize( 10 ) //将a1元素个数改为10,增加的部分值为默认构造
9 a1.resize( 10, 6) //将a1元素个数改为10,增加的部分值为6
10 a1.clear() //清除所有元素
11
2. 用法实例
1 #include <vector>
2 int main() {
3 using namespace std;
4 vector< string > sentence;
5 sentence.reserve( 5 );
6 sentence.push_back( “ Hello, “);
7 sentence.push_back( “how “);
8 sentence.push_back( “are “);
9 sentence.push_back( "you ");
10 sentence.push_back( “?“);
11 copy( sentence.begin(), sentence.end(), ostream_iterator<string>(cout, “ “));
12 cout << endl;
13 cout << sentence.size() << endl;
14 cout << sentence.capacity() << endl;
15 swap( sentence[1], sentence[3]);
16 sentence.insert( find(sentence.begin(), sentence.end(), “?”), “always”);
17 sentence.back() = “!”;
18 copy( sentence.rbegin(), sentence.rend(), ostream_iterator<string>(cout, “ “));
19 cout << endl;
20 }
用vector代替数组使用
3. vector的实现
vector的实现类似于数据结构中的顺序表
attachment:vector.jpg
1 template<class T, class Alloc=alloc>
2 class vector {
3 public:
4 typedef T value_type;
5 typedef value_type* iterator;
6 typedef size_t size_type;
7 protected:
8 iterator start;
9 iterator finish;
10 iterator end_of_storage;
11 //...
12 public:
13 iterator begin() { return start; }
14 iterator end() { return finish; }
15 size_type reserve(size_type n); //改变容量的大小
16 size_type capacity() const { //返回当前容量的大小
17 return size_type(end_of_storage - begin());
18 }
19 void push_back(const T& x) {
20 if(finish != end_of_storage) {
21 construct(finish, x);
22 ++finish;
23 } else {
24 insert_aux(end(), x);
25 }
26 }
27 void insert_aux(iterator position, const T& x) {
28 if(finish != end_of_storage) {
29 construct(finish, *(finish-1));
30 ++finish;
31 T x_copy = x;
32 copy_backward(position, finish-2, finish-1);
33 *position = x_copy;
34 } else {
35 const size_type old_size = size();
36 const size_type len = old_size != 0 ? 2 * old_size : 1;
37 iterator new_start = data_allocator::alloate(len);
38 iterator new_finish = new_start;
39 try {
40 new_finish = uninitialized_copy(start, position, new_start);
41 construct(new_finish, x);
42 ++ new_finish;
43 new_finish = uninitialized_copy(position, finish, new_finish);
44 } catch(...) {
45 destroy(new_start, new_finish);
46 data_allocator::deallocate(new_start, len);
47 throw;
48 }
49 destroy(begin(), end());
50 deallocate();
51 start = new_start;
52 finish = new_finish;
53 end_of_storage = new_start + len;
54 }
55 }
56 };