STL之resize()函数
2016-07-20 17:24
218 查看
size() 目前容器正拥有的元素个数
capacity() 容器能储存的元素个数,即容量
reserve() 重新指定容器能存储数据的个数
resize() 重新指定容器有效的元素个数
设元素原本的v.size()是n 当调用v.resize(m)后,有两种情况:
1.若 m < n ,则只保存容器前m个元素
2.若m > n ,则容器之前储存的n个元素不变,不足m的部分补0
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
while (cin>>n)
{
vector<int>v;//创建一个空的容器
for (int i = 0;i < n;++i)
{
v.push_back(i);
}
int m;
cin>>m;
v.resize(m);
cout<<"重新指定后元素个数:"<<v.size()<<endl;
for (int i = 0;i < m;++i)
{
cout<<v[i]<<" ";
}
cout<<endl;
}
return 0;
}
如果希望多出的部分不是补零,而是赋予指定的值,则可以调用v.resize(m,val)将不足的部分用val填充
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
while (cin>>n)
{
vector<int>v;//创建一个空的容器
for (int i = 0;i < n;++i)
{
v.push_back(i);
}
int m,val;
cin>>m>>val;
v.resize(m,val);
cout<<"重新指定后元素个数:"<<v.size()<<endl;
for (int i = 0;i < m;++i)
{
cout<<v[i]<<" ";
}
cout<<endl;
}
return 0;
}
capacity() 容器能储存的元素个数,即容量
reserve() 重新指定容器能存储数据的个数
resize() 重新指定容器有效的元素个数
设元素原本的v.size()是n 当调用v.resize(m)后,有两种情况:
1.若 m < n ,则只保存容器前m个元素
2.若m > n ,则容器之前储存的n个元素不变,不足m的部分补0
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
while (cin>>n)
{
vector<int>v;//创建一个空的容器
for (int i = 0;i < n;++i)
{
v.push_back(i);
}
int m;
cin>>m;
v.resize(m);
cout<<"重新指定后元素个数:"<<v.size()<<endl;
for (int i = 0;i < m;++i)
{
cout<<v[i]<<" ";
}
cout<<endl;
}
return 0;
}
如果希望多出的部分不是补零,而是赋予指定的值,则可以调用v.resize(m,val)将不足的部分用val填充
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n;
while (cin>>n)
{
vector<int>v;//创建一个空的容器
for (int i = 0;i < n;++i)
{
v.push_back(i);
}
int m,val;
cin>>m>>val;
v.resize(m,val);
cout<<"重新指定后元素个数:"<<v.size()<<endl;
for (int i = 0;i < m;++i)
{
cout<<v[i]<<" ";
}
cout<<endl;
}
return 0;
}
相关文章推荐
- 浅析STL中的常用算法
- STL区间成员函数及区间算法总结
- c++ STL容器总结之:vertor与list的应用
- C++在成员函数中使用STL的find_if函数实例
- 关于STL中list容器的一些总结
- 关于STL中的map容器的一些总结
- 浅析stl序列容器(map和set)的仿函数排序
- STL list链表的用法详细解析
- stl容器set,map,vector之erase用法与返回值详细解析
- STl中的排序算法详细解析
- 关于STL中vector容器的一些总结
- 关于STL中set容器的一些总结
- 简单说说STL的内存管理
- STL与泛型编程(1)---模板
- CppUtest发现的STL容器内存泄漏问题
- STL中算法
- STL简单应用
- vector-list-deque
- 三十分钟掌握STL
- Qt中QSet的使用