C++ vector容器

#include <iostream>

#include <string>

#include <fstream>

#include <vector>

#include <algorithm>

using namespace std;

void printVector(vector<int>& v)

{

for(vector<int>::iterator it = v.begin(); it != v.end(); it++)

{

cout << *it << " ";

}

cout << endl;

}

void test01()

{

vector<int> v1;

for(int i = 0; i < 10; i++)

{

v1.push_back(i);

}

printVector(v1);

vector<int> v2(v1.begin(), v1.end());

printVector(v2);

vector<int> v3(10, 100);

printVector(v3);

vector<int> v4(v3);

printVector(v4);

}

void test02()

{

vector<int> v2;

for(int i = 0; i < 10; i++)

{

v2.push_back(i);

}

printVector(v2);

vector<int> v3;

v3=v2;

printVector(v3);

vector<int> v4;

v4.assign(v2.begin(), v2.end());

printVector(v4);

}

void test03()

{

vector<int> v1;

for(int i = 0; i < 10; i++)

{

v1.push_back(i);

}

printVector(v1);

if(v1.empty())

{

cout << "vector is empty" << endl;

}

else

{

cout << "vector is not empty" << endl;

}

cout << "capacity:" << v1.capacity() << endl;

cout << "size:" << v1.size() << endl;

cout << "max_size:" << v1.max_size() << endl;

cout << "empty:" << v1.empty() << endl;

}

void test04()

{

vector<int> v1;

for(int i = 0; i < 10; i++)

{

v1.push_back(i);

}

printVector(v1);

v1.pop_back();

printVector(v1);

v1.insert(v1.begin(),100);

printVector(v1);

v1.insert(v1.begin(),2,1000);

printVector(v1);

v1.erase(v1.begin());

printVector(v1);

v1.erase(v1.begin(),v1.end());

printVector(v1);

}

void test05()

{

vector<int> v1;

for(int i = 0; i < 10; i++)

{

v1.push_back(i);

}

for(int i = 0; i < v1.size(); i++)

{

cout << v1[i] << " ";

}

for(int i = 0; i < v1.size(); i++)

{

cout << v1.at(i) << " ";

}

cout<<v1.front()<<endl;

cout<<v1.back()<<endl;

}

void test06()

{

vector<int> v1;

for(int i = 0; i < 10; i++)

{

v1.push_back(i);

}

printVector(v1);

vector<int> v2;

for(int i = 10; i < 20; i++)

{

v2.push_back(i);

}

printVector(v2);

v1.swap(v2);

printVector(v1);

printVector(v2);

}

void test07()

{

vector<int> v1;

for(int i = 0; i < 10000000; i++)

{

v1.push_back(i);

}

cout<<v1.capacity()<<endl;

cout<<v1.size()<<endl;

v1.resize(5);

cout<<v1.capacity()<<endl;

cout<<v1.size()<<endl;

vector<int>(v1).swap(v1); //shrink to fit

cout<<v1.capacity()<<endl;

cout<<v1.size()<<endl;

}

void test08()

{

vector<int> v1;

v1.reserve(1000000);

int num = 0;

int *p= NULL;

for(int i=0;i<1000000;i++)

{

v1.push_back(i);

if(p!=&v1[0])

{

p=&v1[0];

num++;

}

}

cout<<"num="<<num<<endl;

}

int main()

{

// test01();

// test02();

// test03();

// test04();

// test05();

// test06();

// test07();

test08();

system("pause");

}

相关推荐
LeeeX!几秒前
基于YOLO11实现明厨亮灶系统实时检测【多场景数据+模型训练、推理、导出】
深度学习·算法·目标检测·数据集·明厨亮灶
红队it2 分钟前
【Spark+Hadoop】基于spark+hadoop游戏评论数据分析可视化大屏(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)✅
大数据·hadoop·分布式·算法·游戏·数据分析·spark
程序员-King.2 分钟前
day125—二分查找—寻找峰值(LeetCode-162)
算法·leetcode·职场和发展
qianbo_insist3 分钟前
基于APAP算法的图像和视频拼接
算法·数学建模·图像拼接
老鼠只爱大米3 分钟前
LeetCode算法题详解 3:无重复字符的最长子串
算法·leetcode·面试题·滑动窗口·无重复字符的最长子串·最长子串
紫色的路4 分钟前
TCP消息边界处理的精妙算法
c++·网络协议·tcp/ip·算法
萧鼎4 分钟前
深入解析 Python 的 Word 模板引擎:docxtpl 全面指南
开发语言·python·word
知乎的哥廷根数学学派4 分钟前
基于高阶统计量引导的小波自适应块阈值地震信号降噪算法(MATLAB)
网络·人工智能·pytorch·深度学习·算法·机器学习·matlab
Chan165 分钟前
场景题:如何设计一个分布式ID
java·开发语言·spring boot·java-ee·intellij-idea
chamu9911 分钟前
C++ 的可调用对象
开发语言·c++