C ++ List resize()函数更改列表容器的大小。
如果n小于当前容器的大小,则列表容器将减少为n个元素,并删除所有扩展n空间的元素。
如果n大于当前容器的大小,则容器的大小会增加,并且可以在扩展的空间中插入更多元素。
void resize(size_type n, value_type val )
n:这是新的容器大小。
val:它是要插入到新构建的列表中的值。
它不返回任何值。
让我们看一个简单的示例,其中n小于当前容器的大小。
#include <iostream> #include<list> using namespace std; int main() { list<int> li={1,2,3,4,5}; list<int>::iterator itr; std::cout << "列表li内容是 :" << std::endl; for(itr=li.begin();itr!=li.end();++itr) cout<<*itr<<","; li.resize(3); cout<<'\n'; std::cout << "调整大小后,列表li的内容 :" << std::endl; for(itr=li.begin();itr!=li.end();++itr) cout<<*itr<<","; return 0; }
输出:
列表li内容是 : 1,2,3,4,5 调整大小后,列表li的内容 : 1,2,3
在此示例中,resize()函数将列表容器的大小减小2。因此,列表的最后两个元素已被删除,输出变为1,2,3。
让我们看一个简单的示例,其中n大于当前容器的大小。
#include <iostream> #include<list> using namespace std; int main() { list<int> li={10,20,30,40}; list<int>::iterator itr; std::cout << "列表li内容是 :" << std::endl; for(itr=li.begin();itr!=li.end();++itr) cout<<*itr<<","; li.resize(7,50); cout<<'\n'; std::cout << "调整大小后,列表li的内容 :" << std::endl; for(itr=li.begin();itr!=li.end();++itr) cout<<*itr<<","; return 0; }
输出:
列表li内容是 : 10,20,30,40 调整大小后,列表li的内容 : 10,20,30,40,50,50,50
在此示例中,resize()函数将列表的大小增加3,并将新元素(即50)插入到新构建的列表中。