C++ STL 中的 list pop_back() 函数


在本文中,我们将讨论 C++ 中 list::pop_back() 函数的工作原理、语法和示例。

什么是 STL 中的 List?

List 是一种数据结构,允许在序列中的任何位置进行常数时间插入和删除操作。列表以双向链表的形式实现。列表允许非连续内存分配。与数组、向量和双端队列相比,列表在任何位置插入、提取和移动元素方面表现更好。在 List 中,对元素的直接访问速度较慢,并且 List 类似于 forward_list,但 forward_list 对象是单向链表,并且只能向前迭代。

什么是 list::pop_back()?

list::pop_back() 是 C++ STL 中的一个内置函数,它在 <list> 头文件中声明。pop_back() 用于从列表容器的末尾或最后删除/弹出元素。当我们使用 pop_back 时,它会删除/弹出最后一个元素,最后一个元素之前的元素成为最后一个元素,并且列表容器的大小减少 1。

语法

list_container.pop_back();

此函数不接受任何参数。

返回值

此函数不返回任何值。

示例

在下面的代码中,我们必须使用 pop_back() 函数从列表的末尾删除元素。

 在线演示

#include <bits/stdc++.h>
using namespace std;
int main(){
   //create a list
   list<int> myList;
   //inserting elements to a list
   myList.push_back(4);
   myList.push_back(9);
   myList.push_back(1);
   myList.push_back(3);
   //list before poping out the elements
   cout<<"list elements before deletion : ";
   for (auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << " ";
   //removing elements from the end of a list using pop_back()
   myList.pop_back();
   // List after removing element from end
   cout << "\nList after deleting element from the end: ";
   for (auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << " ";
   return 0;
}

输出

如果我们运行上述代码,它将生成以下输出

list elements before deletion : 4 9 1 3
List after deleting element from the end: 4 9 1

示例

在下面的代码中,我们必须使用 pop_back() 函数从列表的末尾删除元素,并在删除的同时对列表中的数字进行乘积运算。

 在线演示

#include <bits/stdc++.h>
using namespace std;
int main(){
   list<int> myList;
   int product = 1;
   myList.push_back (40);
   myList.push_back (20);
   myList.push_back (30);
   while (!myList.empty()){
      product*=myList.back();
      myList.pop_back();
   }
   cout<<"The product of elements in my list : "<<product<< '\n';
   return 0;
}

输出

如果我们运行上述代码,它将生成以下输出

The product of elements in my list : 24000

更新于: 2020年3月2日

2K+ 次查看

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告