search
HomeBackend DevelopmentC#.Net TutorialExamples of how to use STL list in C++
Examples of how to use STL list in C++Apr 12, 2017 pm 03:03 PM
liststl

This article mainly introduces the detailed explanation and simple examples of STL list in C++. Friends who need it can refer to it

The detailed explanation of STL list in C++

1. List: The internal implementation is a doubly linked list, which can efficiently perform insertion and deletion, but cannot perform random access

2. Sample program:


#include "stdafx.h" 
#include <iostream> 
#include <list> 
#include <iterator> 
#include <algorithm> 
using namespace std; 
const int num[5] = {1,3,2,4,5}; 
bool status(const int & value) 
{ 
 return value>6?true:false; 
} 
int _tmain(int argc, _TCHAR* argv[]) 
{ 
 list<int> list1; 
 copy(num,num+5,back_insert_iterator<list<int>>(list1)); 
 copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," ")); 
 cout<<endl; 
 list1.sort(greater<int>());//5 4 3 2 1 
 copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," ")); 
 cout<<endl; 
 list<int>::iterator it = list1.begin(); 
 while (it != list1.end()) 
 { 
  (*it) += 2; 
  it++; 
 } 
 //7 6 5 4 3 
 list<int>::reverse_iterator re_it = list1.rbegin(); 
 cout<<"从后向前输出: "; 
 while (re_it != list1.rend()) 
 { 
  cout<<*re_it<<" "; 
  re_it++; 
 } 
 cout<<endl; 
 list1.reverse();// 3 4 5 6 7 
 list1.push_back(8);//3 4 5 6 7 8 
 list1.pop_front();//4 5 6 7 8 
 list1.remove(6);//4 5 7 8 
 list1.remove_if(status);// 4 5 
 list1.resize(4);// 4 5 0 0 
 list1.resize(6,1);// 4 5 0 0 1 1 
 list1.unique();//4 5 0 1 
 copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," ")); 
 cout<<endl; 
 list1.clear(); 
 cout<<"当前list1含有元素个数:"<<list1.size()<<endl; 
 list1.push_back(7);//list1:7 
 list<int> list2(3,2);//2 2 2 
 list2.merge(list1,greater<int>());//list2: 7 2 2 2 
 list2.insert(++list2.begin(),3);//list2: 7 3 2 2 2 
 list2.swap(list1);//list1:7 3 2 2 2 list2:empty 
 list1.erase(++list1.begin(),list1.end());// 7 
 copy(list1.begin(),list1.end(),ostream_iterator<int>(cout," ")); 
 cout<<endl; 
 system("pause"); 
}

Run result picture:


3. List method

##destructorDestructor##operator=assignfrontbackbeginendrbeginrendpush_backpush_frontpop_backpop_frontcleareraseremove remove_if empty
##list members

Description

constructor

Constructor

##Assignment overloaded operator

Assign value

Returns a reference to the first element

Returns a reference to the last element

Returns the iterator of the first element

Returns the iterator at the next position of the last element

Returns the backward pointer reverse_iterator of the last element of the linked list

Return the reverse_iterator at the next position of the first element of the linked list

Add a data to the end of the linked list

Add a data to the head of the linked list

Delete an element at the end of the linked list

Delete one element from the head of the linked list

Delete all elements

Delete an element or a range of elements (two overloads)

Delete elements with matching values ​​in the linked list (all matching elements are deleted)

Delete elements that meet the conditions (traverse the linked list once), the parameter is a custom callback function

Determine whether the linked list is empty

##max_size
Return The maximum possible length of the linked list

size
Returns the number of elements in the linked list

resize
Redefine the length of the linked list (two overloaded functions)

reverse
Reverse linked list

sort
Sort the linked list , default ascending order

merge
Merge two ordered linked lists and make them ordered

splice
Combine two linked lists (three overloaded functions) and clear the second linked list after combining

insert
Insert one or more elements at the specified position (three overloaded functions)

swap
Swap two linked lists (two overloads)

unique
Delete adjacent duplicate elements

The above is the detailed content of Examples of how to use STL list in C++. For more information, please follow other related articles on the PHP Chinese website!

Statement
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
如何在 C++ STL 中实现定制的比较器?如何在 C++ STL 中实现定制的比较器?Jun 05, 2024 am 11:50 AM

实现定制比较器可以通过创建一个类,重载运算符()来实现,该运算符接受两个参数并指示比较结果。例如,StringLengthComparator类通过比较字符串长度来排序字符串:创建一个类并重载运算符(),返回布尔值指示比较结果。在容器算法中使用定制比较器进行排序。通过定制比较器,我们可以根据自定义标准对数据进行排序或比较,即使需要使用自定义比较标准。

如何获取C++ STL容器的大小?如何获取C++ STL容器的大小?Jun 05, 2024 pm 06:20 PM

通过使用容器的size()成员函数,可以获取容器中元素的数量。例如,vector容器的size()函数返回元素数量,list容器的size()函数返回元素数量,string容器的length()函数返回字符数量,deque容器的capacity()函数返回分配的内存块数量。

如何设计自定义的 STL 函数对象来提高代码的可重用性?如何设计自定义的 STL 函数对象来提高代码的可重用性?Apr 25, 2024 pm 02:57 PM

使用STL函数对象可提高可重用性,包含以下步骤:定义函数对象接口(创建类并继承自std::unary_function或std::binary_function)重载operator()以定义函数行为在重载的operator()中实现所需的功能通过STL算法(如std::transform)使用函数对象

使用 C++ STL 时如何处理哈希冲突?使用 C++ STL 时如何处理哈希冲突?Jun 01, 2024 am 11:06 AM

C++STL哈希冲突的处理方式有:链地址法:使用链表存储冲突元素,适用性好。开放寻址法:在桶中查找可用位置存储元素,子方法有:线性探测:按顺序查找下一个可用位置。二次探测:以二次方形式跳过位置进行查找。

C++ STL容器中常见类型有哪些?C++ STL容器中常见类型有哪些?Jun 02, 2024 pm 02:11 PM

C++STL中最常见的容器类型分别是Vector、List、Deque、Set、Map、Stack和Queue。这些容器为不同的数据存储需求提供了解决方案,例如动态数组、双向链表和基于键和值的关联容器。实战中,我们可以使用STL容器高效地组织和访问数据,例如存储学生成绩。

如何利用 C++ STL 实现代码的可读性和维护性?如何利用 C++ STL 实现代码的可读性和维护性?Jun 04, 2024 pm 06:08 PM

通过利用C++标准模板库(STL),我们可以提升代码的可读性和维护性:1.使用容器取代原始数组,提高类型安全性和内存管理;2.利用算法简化复杂任务,提高效率;3.使用迭代器增强遍历,简化代码;4.使用智能指针提升内存管理,减少内存泄漏和悬垂指针。

如何排序C++ STL容器?如何排序C++ STL容器?Jun 02, 2024 pm 08:22 PM

C++中对STL容器排序的方法:使用sort()函数,原地排序容器,如std::vector。使用有序容器std::set和std::map,元素在插入时自动排序。对于自定义排序顺序,可以使用自定义比较器类,如按字母顺序排序字符串向量。

C++ STL中的迭代器C++ STL中的迭代器Aug 21, 2023 pm 08:52 PM

C++STL(StandardTemplateLibrary)是C++程序语言的标准库之一,它包含了一系列的标准数据结构和算法。在STL中,迭代器(iterator)是一种非常重要的工具,用于在STL的容器中进行遍历和访问。迭代器是一个类似于指针的对象,它可以指向容器(例如vector、list、set、map等)中的某个元素,并可以在容器中进行移动、

See all articles

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)
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool