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


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

什么是 STL 中的 List

List 是一种数据结构,允许在序列中的任何位置进行常数时间插入和删除操作。列表以双向链表的形式实现。列表允许非连续内存分配。与数组、向量和双端队列相比,列表在任何位置插入、提取和移动元素方面表现更好。在 List 中,对元素的直接访问速度较慢,并且列表类似于 forward_list,但 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(){
   //create a list
   list<int> myList;
   //insert elements to the list
   myList.push_back(1);
   myList.push_back(2);
   myList.push_back(3);
   myList.push_back(4);
   //elemets in th list before Resize
   cout << "List elements are : ";
   for (auto i = myList.begin(); i!= myList.end(); i++)
      cout << *i << " ";
   //Resizing list
   myList.resize(5);
   cout<<"\nList after resize: ";
   for (auto i = myList.begin(); i!= myList.end(); i++)
      cout << *i << " ";
   //Resizing list 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

更新于: 2020-02-26

223 次查看

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告

© . All rights reserved.