C++ named requirements: SequenceContainer
A SequenceContainer is a Container that stores objects of the same type in a linear arrangement.
Requirements
The type X satisfies SequenceContainer if
-  The type Xsatisfies Container, and
Given
-  T, the element type ofX
-  A, the allocator type ofX: X::allocator_type if it exists, otherwise std::allocator<T>
-  a, rvalue expression of typeX
-  p, a valid const iterator intoa
-  q, a valid dereferenceable const iterator intoa
-  q1andq2, two const iterators intoasuch that [q1, q2) is a valid range
-  iandj, InputIterators such that [i, j) is a valid range and that the iterators refer to elements implicitly convertible tovalue_type
-  il, an object of type std::initializer_list<value_type>
-  n, a value of type X::size_type
-  t, an lvalue or const rvalue of type X::value_type
-  rv, a non-const rvalue of type X::value_type
-  Args: a template parameter pack
-  args: a function parameter pack with the pattern Arg&&
The following expressions must be valid and have their specified effects for all sequence containers except std::array:
| expression | return type | effects | precondition | postcondition | 
|---|---|---|---|---|
| X(n, t) X a(n, t) | Constructs the sequence container holding ncopies oft | Tis CopyInsertable intoX | std::distance(begin(),end()) == n | |
| X(i, j) X a(i, j) | Constructs the sequence container equal, element-wise, to the range [i,j) | Tis EmplaceConstructible from*iintoX(only for std::vector) If the iterators are not ForwardIterators, T must be CopyInsertable | std::distance(begin(),end()) == std::distance(i,j) | |
| X(il) | X(il.begin(), il.end()) | |||
| a = il | X& | Assigns the range represented by ilintoa[1] | T is CopyInsertable and CopyAssignable | Existing elements of aare destroyed or assigned to | 
| a.emplace(p,args) | iterator | Insert an object of type T, constructed with std::forward<Args>(args) beforep | Tis CopyInsertable(for std::vector and std::deque)  | Returned iterator points at the element constructed from argsintoa | 
| a.insert(p,t) | iterator | Inserts a copy of tbeforep | Tis CopyInsertable(for std::vector and std::deque)  | Returned iterator points at the copy of tinserted intoa | 
| a.insert(p,rv) | iterator | Inserts a copy of rvbeforep, possibly using move semantics | Tis MoveInsertable(for std::vector and std::deque)  | Returned iterator points at the copy of rvinserted intoa | 
| a.insert(p,n,t) | iterator | Inserts ncopies oftbeforep | Tis CopyInsertable and CopyAssignable | Returned iterator points at the copy of the first element inserted into aor ispfor n==0 | 
| a.insert(p,i,j) | iterator | Inserts copies of elements in [i, j)beforep | Tis EmplaceConstructible andiandjare not ina(only for std::vector) If the iterators are not ForwardIterators, T must be MoveInsertable and MoveAssignable | Each iterator in [i,j)is dereferenced once. Returned iterator points at the copy of the first element inserted intoaor ispfor i==j | 
| a.insert(p, il) | iterator | a.insert(p,il.begin(),il.end()) | Returned iterator points at the copy of the first element inserted into aor ispifilis empty. | |
| a.erase(q) | iterator | Erases the element pointed to by q | (std::deque, std::vector) Tis MoveAssignable | Returned iterator points at the element that was immediately following qprior to erasure, or a.end() if no such element exists. | 
| a.erase(q1,q2) | iterator | Erases elements in [q1,q2) | (std::deque, std::vector) Tis MoveAssignable | Returned iterator points at the element that was pointed by q2prior to any erasure, or a.end() if no such element exists. | 
| a.clear() | void | Destroys all elements in a | All references, pointers, and iterators are invalidated, including the end iterator. a.empty() == true. | |
| a.assign(i,j) | void | Replaces elements in a with a copy of [i, j) | Tis EmplaceConstructible andi,jnot ina(std::vector) If not ForwardIterator.  | Each iterator in [i,j)is dereferenced once | 
| a.assign(il) | void | a.assign(il.begin(),il.end()) | ||
| a.assign(n,t) | void | Replaces elements in awithncopies oft | Tis CopyInsertable and CopyAssignable | |
| notes | ||||
| 
 | ||||
The following expressions must be valid and have their specified effects for the sequence containers named:
| expression | return type | effects | preconditions | containers | 
|---|---|---|---|---|
| a.front() | reference
 | Equivalent to *a.begin() | (all) | |
| a.back() | reference
 | Equivalent to { auto tmp = a.end(); --tmp; return *tmp; } | std::basic_string std::array std::deque std::list std::vector | |
| a.emplace_front(args) | void | Prepends a Tconstructed with std::forward<Args>(args)... | Tis EmplaceConstructible intoXfromargs | std::deque std::forward_list std::list | 
| a.emplace_back(args) | void | Appends a Tconstructed with std::forward<Args>(args)... | Tis EmplaceConstructible intoXfromargs(std::vector only)  | std::deque std::list std::vector | 
| a.push_front(t) | void | Prepends a copy of t | Tis CopyInsertable intoX | std::deque std::forward_list std::list | 
| a.push_front(rv) | void | Prepends a copy of rv, possibly using move semantics | Tis MoveInsertable intoX | std::deque std::forward_list std::list | 
| a.push_back(t) | void | Appends a copy of t | Tis CopyInsertable intoX | std::basic_string std::deque std::list std::vector | 
| a.push_back(rv) | void | Appends a copy of rv, possibly using move semantics | Tis MoveInsertable intoX | std::basic_string std::deque std::list std::vector | 
| a.pop_front() | void | Destroys the first element. | a.empty() == false | std::deque std::forward_list std::list | 
| a.pop_back() | void | Destroys the last element | a.empty() == false | std::basic_string std::deque std::list std::vector | 
| a[n] | reference
 | Equivalent to *(n + a.begin()) | std::basic_string std::array std::deque std::vector | |
| a.at(n) | reference
 | Equivalent to *(n + a.begin()), except that out_of_range is thrown if n>=size() | std::basic_string std::array std::deque std::vector | 
Additionally, for every sequence container, the constructor template that takes two input iterators and the member function template overloads of insert(), append(), assign(), replace() that take two input iterators do not participate in overload resolution if the corresponding template argument does not satisfy InputIterator.
Sequence containers in the standard library
| stores and manipulates sequences of characters (class template) | |
| (C++11) | static contiguous array (class template) | 
| dynamic contiguous array (class template) | |
| double-ended queue (class template) | |
| (C++11) | singly-linked list (class template) | 
| doubly-linked list (class template) | 
Trade-offs / usage notes
| std::array | Fast access but fixed number of elements | 
| std::vector | Fast access but mostly inefficient insertions/deletions | 
| std::list std::forward_list | Efficient insertion/deletion in the middle of the sequence | 
| std::deque | Efficient insertion/deletion at the beginning and at the end of the sequence |