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

c++server side programmingprogramming

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

STL 中的 List 是什么?

List 是一种数据结构,允许在任意位置以恒定时间顺序插入和删除元素。List 实现为双向链表。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(){
   //创建列表
   list<int> myList;
   //将元素插入列表
   myList.push_back(4);
   myList.push_back(9);
   myList.push_back(1);
   myList.push_back(3);
   //弹出元素前的列表
   cout<<"删除前的列表元素 : ";
   for (auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << & " & ";;
   // 使用 pop_back() 从列表末尾移除元素
   myList.pop_back();
   // 从列表末尾移除元素后的列表
   cout << "\n从末尾删除元素后的列表: ";
   for (auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << " ";
   return 0;
}

输出

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

删除前列表元素:4 9 1 3
从末尾删除元素后的列表: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

相关文章