Table of Contents
Group pair
1. Associative container
2. Common operations of associative containers and sequential containers
1. Constructors shared by associative containers and sequential containers
2. Other functions shared by associative containers and sequential containers
3. Operations provided by the pair type
4. Creation and initialization of pair
Home Backend Development C#.Net Tutorial Summary of common containers in C++_STL: associative containers and sequential containers in pairs

Summary of common containers in C++_STL: associative containers and sequential containers in pairs

Jul 28, 2018 am 11:31 AM

Group pair

In this part, we first introduce the common operations of associated containers and sequential containers in a pair group pair, and then introduce the commonly used ones. Several specific associated containers.

1. Associative container

Associative container is a type of storage object collection that supports efficient query by key. Most of the behavior of associative containers is the same as that of sequential containers. The essential difference between the two is that associative containers store and read elements by key, while sequential containers store and access elements sequentially by their position in the container.
Each element of the associated container contains a key and a real value. When an element is inserted into an associative container, the container's internal data structure places the element in the appropriate location according to certain rules based on the size of its key value. Associative containers have no so-called head and tail, only the largest element and the smallest element. Associative containers do not provide front, push_front, pop_front, back, push_back, and pop_back operations.
Standard STL associative containers are divided into two categories: set (set) and map (mapping), as well as their derivatives multiset (multi-key set) and multimap (multi-key mapping table). The underlying mechanisms of these containers are all implemented in RB-tree (red-black tree).

2. Common operations of associative containers and sequential containers

1. Constructors shared by associative containers and sequential containers

Associative containers share most of the operations of sequential containers, but Not all, associative containers can use the following three constructors:

C<T> c;
Copy after login
  • 1

Create an empty container named c. C is the container type name, such as vector, and T is the element type, such as int or string. Works with all containers.

C<T> c(c2);
Copy after login
  • 1

Create a copy c of container c2; c and c2 must have the same container type and store the same type of elements. Works with all containers.

C<T> c(b, e);
Copy after login
  • 1

Create c whose elements are copies of the elements in the range identified by iterators b and e. Works with all containers.

2. Other functions shared by associative containers and sequential containers

  1. Associative containers cannot be defined by the size of the container, because then the value corresponding to the key cannot be known What is it.

  2. Associative containers support some relational operators of sequential containers.

  3. Associated containers support begin, end, rbegin, and rend operations.

  4. Associative containers support swap and assignment operations, but do not provide the assign function.

  5. Associated containers support clear and erase functions, but the erase operation of associated containers returns the void type.

  6. Associated containers support the size(), max_size(), and empty() functions as container size operations, but do not support the resize() function.

3. Operations provided by the pair type

The pair pair contains two data values. The specific usage is as follows:

pair<T1, T2> p1;
Copy after login
  • 1

Create an empty pair object whose two elements are of type T1 and T2 respectively. , initialized with value.

pair<T1, T2> p1(v1, v2);
Copy after login
  • 1

Create a pair object, its two elements are of type T1 and T2 respectively, where the first member is initialized to v1, The second member is initialized to v2.

make_pair(v1, v2);
Copy after login
  • 1

Create a new pair object with v1 and v2 values, and the types of its elements are the types of v1 and v2 respectively.

p1 < p2;
Copy after login
  • 1

The less than operation between two pair objects, its definition follows dictionary order: if p1.first< p2.first or !(p2.first<p1.first)&&p1.second<p2.second, returns true.

p1 == p2;
Copy after login
  • 1

If the first member and second member of two pair objects are equal in sequence, then the two objects are equal. This operation uses The == operator for its elements.

p.first、p.second;
Copy after login
  • 1

Returns the public data members named first and second in p.

4. Creation and initialization of pair

When creating a pair object, you must provide two type names. Each of the two data members of the pair object corresponds to one. The two type names can be different. . If no explicit initialization is provided when creating a pair object, the default constructor is called to initialize its members; you can also use () to directly display the initialization formula when creating an object:
- pair Object name ;

If you use multiple identical pair objects, you can also use typedef to simplify their declaration:

typedef  pair <string, string>  Author;
Author 对象名(初始值1,初始值2);
Copy after login
  • 1

  • 2

For the pair class, you can directly access its data members. Its members are all public and are named first member and second member respectively. They can be accessed using the dot operator.

Related articles:

c The use of Iterator in STL standard container

c Summary of review points z-12——STL string

Related videos:

C# Tutorial

The above is the detailed content of Summary of common containers in C++_STL: associative containers and sequential containers in pairs. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to use char array in C language How to use char array in C language Apr 03, 2025 pm 03:24 PM

The char array stores character sequences in C language and is declared as char array_name[size]. The access element is passed through the subscript operator, and the element ends with the null terminator '\0', which represents the end point of the string. The C language provides a variety of string manipulation functions, such as strlen(), strcpy(), strcat() and strcmp().

How to handle special characters in C language How to handle special characters in C language Apr 03, 2025 pm 03:18 PM

In C language, special characters are processed through escape sequences, such as: \n represents line breaks. \t means tab character. Use escape sequences or character constants to represent special characters, such as char c = '\n'. Note that the backslash needs to be escaped twice. Different platforms and compilers may have different escape sequences, please consult the documentation.

What is the role of char in C strings What is the role of char in C strings Apr 03, 2025 pm 03:15 PM

In C, the char type is used in strings: 1. Store a single character; 2. Use an array to represent a string and end with a null terminator; 3. Operate through a string operation function; 4. Read or output a string from the keyboard.

How to use various symbols in C language How to use various symbols in C language Apr 03, 2025 pm 04:48 PM

The usage methods of symbols in C language cover arithmetic, assignment, conditions, logic, bit operators, etc. Arithmetic operators are used for basic mathematical operations, assignment operators are used for assignment and addition, subtraction, multiplication and division assignment, condition operators are used for different operations according to conditions, logical operators are used for logical operations, bit operators are used for bit-level operations, and special constants are used to represent null pointers, end-of-file markers, and non-numeric values.

The difference between multithreading and asynchronous c# The difference between multithreading and asynchronous c# Apr 03, 2025 pm 02:57 PM

The difference between multithreading and asynchronous is that multithreading executes multiple threads at the same time, while asynchronously performs operations without blocking the current thread. Multithreading is used for compute-intensive tasks, while asynchronously is used for user interaction. The advantage of multi-threading is to improve computing performance, while the advantage of asynchronous is to not block UI threads. Choosing multithreading or asynchronous depends on the nature of the task: Computation-intensive tasks use multithreading, tasks that interact with external resources and need to keep UI responsiveness use asynchronous.

How to convert char in C language How to convert char in C language Apr 03, 2025 pm 03:21 PM

In C language, char type conversion can be directly converted to another type by: casting: using casting characters. Automatic type conversion: When one type of data can accommodate another type of value, the compiler automatically converts it.

What is the function of C language sum? What is the function of C language sum? Apr 03, 2025 pm 02:21 PM

There is no built-in sum function in C language, so it needs to be written by yourself. Sum can be achieved by traversing the array and accumulating elements: Loop version: Sum is calculated using for loop and array length. Pointer version: Use pointers to point to array elements, and efficient summing is achieved through self-increment pointers. Dynamically allocate array version: Dynamically allocate arrays and manage memory yourself, ensuring that allocated memory is freed to prevent memory leaks.

Avoid errors caused by default in C switch statements Avoid errors caused by default in C switch statements Apr 03, 2025 pm 03:45 PM

A strategy to avoid errors caused by default in C switch statements: use enums instead of constants, limiting the value of the case statement to a valid member of the enum. Use fallthrough in the last case statement to let the program continue to execute the following code. For switch statements without fallthrough, always add a default statement for error handling or provide default behavior.

See all articles