在C ++ STL中列出resize()函数

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

什么是STL中的列表

列表是一种数据结构,允许按时间顺序在任意位置进行插入和删除。列表被实现为双向链接列表。列表允许非连续的内存分配。与数组,向量和双端队列相比,列表在容器中的任何位置执行元素的插入提取和移动效果更好。在列表中,对元素的直接访问很慢,并且列表类似于forward_list,但是转发列表对象是单个链接列表,并且只能迭代转发。

什么是list::resize()?

list::resize()是C ++ STL中的内置函数,在头文件中声明。resize()用于调整列表容器的大小。它调整容器的大小,以便包含我们在函数参数中给出的元素数量。

语法

list_name.resize(int n);

要么

list_name.resize(int n, const value_type &val);

此函数可以接受其中一个或两个参数。

参数

  • n-这是一个整数类型,用于定义新的容器大小(元素数)。

  • val-将其内容复制到容器中所有空间的对象。

返回值

此函数不返回任何内容。它只会调整容器的大小。

示例

#include <bits/stdc++.h>
using namespace std;
int main(){
   //创建一个列表
   list<int> myList;
   //将元素插入列表
   myList.push_back(1);
   myList.push_back(2);
   myList.push_back(3);
   myList.push_back(4);
   //调整大小前列表中的元素
   cout << "List elements are : ";
   for (auto i = myList.begin(); i!= myList.end(); i++)
      cout << *i << " ";
   //调整大小列表
   myList.resize(5);
   cout<<"\nList after resize: ";
   for (auto i = myList.begin(); i!= myList.end(); i++)
      cout << *i << " ";
   //调整大小列表 again
   myList.resize(6);
   cout<<"\nList after resizing it again : ";
   for (auto i = myList.begin(); i != myList.end(); i++)
      cout << *i << " ";
   return 0;
}

输出结果

如果我们运行上面的代码,那么它将生成以下输出

List elements are : 1 2 3 4
List after resize : 1 2 3 4 0
List after resizing it again : 1 2 3 4 0 0