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");

}

相关推荐
不想写代码的星星44 分钟前
std::function 详解:用法、原理与现代 C++ 最佳实践
c++
CoovallyAIHub19 小时前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
木心月转码ing21 小时前
Hot100-Day14-T33搜索旋转排序数组
算法
会员源码网1 天前
内存泄漏(如未关闭流、缓存无限增长)
算法
颜酱1 天前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱1 天前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法
CoovallyAIHub2 天前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github