Skip to content
  • General
  • Programming
  • DS & Algo
  • System Design
  • Interview Questions
  • Home
  • YouTube
  • About
  • Contact
Learn to Code and Code to Learn

Learn to Code and Code to Learn

Your Journey to Code Mastery

  • General
    • Setup
  • Programming
    • C++
    • C++-11
    • c++-14
    • Python
  • DS & Algo
    • DS
    • Algo
      • Competitive Programming
        • Leetcode Problems
  • System Design
    • Design Pattern
    • SOLID Principle
  • Interview Questions
    • C++
    • Company Wise
  • Toggle search form

List in C++ STL

Posted on December 26, 2021December 26, 2021 By thecodepathshala 3 Comments on List in C++ STL

Lists are sequence containers that allow constant time insert and erase operations anywhere within the sequence, and iteration in both directions. As compared to vector, list has slow traversal, but once a position has been found, insertion and deletion are quick. 

  • List containers are implemented as doubly-linked lists
  • For implementing a singly linked list, we use forward_list
  • Advantage :
    • Compared to other base standard sequence containers (array, vector and deque), lists perform generally better in inserting, extracting and moving elements in any position within the container.
    • sorting algorithms uses list.
  • Disadvantage :
    • The main drawback of lists and forward_lists compared to these other sequence containers is that they lack direct access to the elements by their position because it has non-contiguous memory allocation. For example, to access the 6th element in a list, one has to iterate from either the beginning or the end to that position, which takes linear time.
    • It also consumes some extra memory to keep the linking information associated to each element.
Functions used with List:

Iterators:
begin : Return iterator to beginning (public member function )
end : Return iterator to end (public member function )
rbegin : Return reverse iterator to reverse beginning (public member function )
rend : Return reverse iterator to reverse end (public member function )
cbegin : Return const_iterator to beginning (public member function )
cend : Return const_iterator to end (public member function )
crbegin : Return const_reverse_iterator to reverse beginning (public member function )
crend : Return const_reverse_iterator to reverse end (public member function )

Capacity:
empty : Test whether container is empty (public member function )
size : Return size (public member function )
max_size : Return maximum size (public member function )

Element access:
front : Access first element (public member function )
back : Access last element (public member function )

Modifiers:
assign : Assign new content to container (public member function )
emplace_front : Construct and insert element at beginning (public member function )
push_front : Insert element at beginning (public member function )
pop_front : Delete first element (public member function )
emplace_back :
Construct and insert element at the end (public member function )
push_back : Add element at the end (public member function )
pop_back : Delete last element (public member function )
emplace : Construct and insert element (public member function )
insert : Insert elements (public member function )
erase :
Erase elements (public member function )
swap
: Swap content (public member function )
resize : Change size (public member function )
clear : Clear content (public member function )

Operations:
splice : Transfer elements from list to list (public member function )
remove : Remove elements with specific value (public member function )
remove_if : Remove elements fulfilling condition (public member function template )
unique : Remove duplicate values (public member function )
merge : Merge sorted lists (public member function )
sort : Sort elements in container (public member function )
reverse : Reverse the order of elements (public member function )

Observers:
get_allocator : Get allocator (public member function )

// program to show the working of some functions of List
#include <iostream>
#include <list>
#include <iterator>
using namespace std;

//function for printing the elements in a list
void showlist(list <int> lst)
{
	list <int> :: iterator it;
	for(it = lst.begin(); it != lst.end(); ++it)
		cout << '\t' << *it;
	cout << '\n';
}

int main()
{
	list <int> tsp_list1, tsp_list2;
	for (int i = 0; i < 10; ++i)
	{
		tsp_list1.push_back(i * 2);
		tsp_list2.push_front(i * 3);
	}
	cout << "\nList 1 (tsp_list1) is : ";
	showlist(tsp_list1);
	cout << "\nList 2 (tsp_list2) is : ";
	showlist(tsp_list2);
	cout << "\ntsp_list1.front() : " << tsp_list1.front();
	cout << "\ntsp_list1.back() : " << tsp_list1.back();
	cout << "\ntsp_list1.pop_front() : ";
	tsp_list1.pop_front();
	showlist(tsp_list1);
	cout << "\ntsp_list2.pop_back() : ";
	tsp_list2.pop_back();
	showlist(tsp_list2);
	cout << "\ntsp_list1.reverse() : ";
	tsp_list1.reverse();
	showlist(tsp_list1);
	cout << "\ntsp_list2.sort(): ";
	tsp_list2.sort();
	showlist(tsp_list2);
	return 0;
}

/*
Output : 
List 1 (tsp_list1) is :     0    2    4    6    
8    10    12    14    16    18

List 2 (tsp_list2) is :     27    24    21    18    
15    12    9    6    3    0

tsp_list1.front() : 0
tsp_list1.back() : 18
tsp_list1.pop_front() :     2    4    6    8    
10    12    14    16    18

tsp_list2.pop_back() :     27    24    21    18    
15    12    9    6    3

tsp_list1.reverse() :     18    16    14    12    
10    8    6    4    2

tsp_list2.sort():     3    6    9    12    
15    18    21    24    27
*/
C++, Programming, STL

Post navigation

Previous Post: Vector in C++ STL
Next Post: Deque in C++ STL

More Related Articles

Day-2 / Part – 1 : Basic Input and Output in C Mastering in C programming (Crash Course)
Single Responsibility Principle C++
C program to check whether a number is prime number or not C Programming
C program to find prime factors of a number C Programming
C program to find maximum between three numbers C Programming
Templates in C++ C++

Comments (3) on “List in C++ STL”

  1. Pingback: STL(Standard Template Library) - The Code Pathshala
  2. Pingback: Forward_list in C++ STL - The Code Pathshala
  3. idealizes says:
    July 17, 2022 at 1:40 pm

    Ӏ used to be able tߋ find gⲟod advice from уour cߋntent.

    Reply

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Archives

  • August 2025
  • March 2025
  • February 2025
  • January 2025
  • December 2024
  • August 2024
  • April 2024
  • March 2024
  • February 2024
  • January 2024
  • December 2023
  • November 2023
  • September 2023
  • February 2023
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021

Categories

  • Algo
  • Array in C
  • C Programming
  • C++
  • C++
  • Company Wise
  • Competitive Programming
  • Design Pattern
  • DS
  • DS & Algo
  • Fast and Slow Pointer
  • fixed size sliding window
  • General
  • GFG
  • GFG PTOD
  • Interview Questions
  • Leetcode Problems
  • Leetcode PTOD
  • Leetcode Top Interview 150
  • LLD
  • Low-level design
  • Mastering in C programming (Crash Course)
  • Programming
  • Roadmap
  • Setup
  • Setup
  • sliding window
  • SOLID Principle
  • STL
  • string in c
  • System Design
  • Top X

Tags

algorithm array bactracking basic c++ coding interview C Programming Crash Course data structure and algorithm design pattern dsa easy Fixed size sliding window fubctions GFD gfg GFG PTOD hard jump game LC PTOD leetcode Leetcode PTOD Leetcode Top Interview 150 LLD loop loops Low-level design Mastering C Programming in 15 Days matrix medium recursion rotate array searching&sorting sliding window solid STL string string in c sunction in c system design Template in C++ Top Top 20 coding patterns to master MAANG Interview Top interview 150

Database Sharding #interview #shorts #ytshorts #apple #google #facebook #meta #amazon #softwareengineer 

what is database Sharding 
when database Sharding
Database Sharding #interview #shorts #ytshorts #apple #google #facebook #meta #amazon #software
Use of CDN | what is CDN #cdn #systemdesign #interview #shorts #google #apple #meta #amazon #adobe

content delivery network 
what is cdn
what is the use of cdn
Use of CDN | what is CDN #cdn #systemdesign #interview #shorts #google #apple #meta #amazon #adobe
Horizontal vs Vertical Scaling #systemdesign #google #microsoft #interview #shorts #apple #FAANG

Tags:

horizontal vs vertical scaling, vertical vs horizontal scaling, horizontal scaling vs vertical scaling, horizontal vs vertical scaling pros and cons, vertical scaling vs horizontal scaling, horizontal scaling vs vertical scaling in aws, horizontal vs vertical scaling in cloud computing, horizontal and vertical scaling, horizontal vs vertical, horizontal and vertical scaling in cloud computing, difference between horizontal and vertical scaling, diagonal scaling vs horizontal scaling


#Scalability #HorizontalScaling #VerticalScaling #SystemArchitecture #Computing #technologynews #HorizontalScaling
#VerticalScaling
#Scalability
#ScaleOut
#ScaleUp
#SystemScaling
#DistributedSystems
#InfrastructureScaling
#CloudScaling
#ResourceScaling
#ScaleOut
#DistributedSystems
#LoadBalancing
#CloudScaling
#Scalability
#HorizontalScalingVsVerticalScaling
#HorizontalScalingExplained
#Elasticity
#DistributedComputing
#SystemArchitecture
#HighAvailability
#FaultTolerance
#ScalingStrategies
#InfrastructureScaling
Horizontal vs Vertical Scaling #systemdesign #google #microsoft #interview #shorts #apple #FAANG
😇why Instagram load fast❓⁉️ #Instagram #interview #apple #iit #microsoft
😇why Instagram load fast❓⁉️ #Instagram #interview #apple #iit #microsoft
Load balancer in 30 second #shorts #youtubeshorts #interview #hld #systemdesign #iit #google #apple
Real life example | Abstract factory | Design pattern #designpatterns #lowleveldesign #interview
Advantage of Abstract factory design pattern #interview #lld #google #apple #meta #facebook
Abstract factory design pattern | what? Why? How? #interview #lld #google #apple #meta #facebook
Master Abstract Factory Design Pattern in C++ | Real-World Examples & Code Explanation

In this video, we break down the Abstract Factory Design Pattern in C++ step-by-step. You’ll learn:
✅ What is Abstract Factory Pattern
✅ When & why to use it in C++
✅ UML diagram explanation
✅ Real-world examples for better understanding
✅ Complete C++ code implementation

Whether you’re preparing for FAANG interviews, learning Design Patterns, or improving your Object-Oriented Programming skills, this tutorial will help you write clean, scalable, and maintainable C++ code.

Keywords:
abstract factory c++, abstract factory design pattern c++, abstract factory design pattern example, creational design patterns in c++, design patterns in c++ with examples, faang interview preparation, c++ oops concepts
abstract factory pattern, c programming, design patterns in c, object oriented design, system architecture, software design, c language tutorial, creational patterns, software engineering, c programming tutorial, factory method pattern, design principles, object creation, software development, programming concepts
master abstract factory design pattern in c,
abstract factory design pattern php,
abstract factory design pattern c#,
abstract factory design pattern vs factory pattern,
abstract factory design pattern js,
abstract factory design pattern c++,
abstract factory design pattern example,
factory and abstract factory design pattern in java,
factory method design pattern php,
abstract factory and factory design pattern,
factory pattern and abstract factory pattern,
abstract factory design pattern example c#,
java abstract factory design pattern,
abstract factory method design pattern,
abstract factory design pattern java,
abstract factory design pattern example java,
abstract factory design pattern typescript,
abstract factory design pattern in java,
abstract factory design pattern in c#,
abstract factory design patterns in java,
factory pattern design pattern,
abstract factory design pattern python

#Cpp #DesignPatterns #AbstractFactory #Programming #codewithme 
#masterabstractfactorydesignpatterninc++ #abstractfactorydesignpatterninc++ #masterabstractfactorydesignpatterninc++hindi #masterabstractfactorydesignpatterninc++and #masterabstractfactorydesignpatterninc++andc
Master Abstract Factory Design Pattern in C++ | Real-World Examples & Code Explanation
Load More... Subscribe

Recent Posts

  • Palindrome Linked List
  • Find the Duplicate Number
  • Remove Nth Node From End of List
  • Linked List Cycle II
  • Decode the string | GFG PTOD | 01 Mar| Medium level | STACK

    Recent Comments

    1. reebjnhzey on GFG PTOD | 23 Feb | Next Greater Element | Medium level | STACK
    2. 서울여성전용마사지 on C program to check Leap Year
    3. http://boyarka-inform.com/ on C program to enter basic salary and calculate gross salary of an employee
    4. Denny on C program to enter basic salary and calculate gross salary of an employee
    5. Cabanon Eco on C program to check Leap Year

    Copyright © 2025 Learn to Code and Code to Learn.

    Powered by PressBook Blog WordPress theme