当前位置: 首页> 房产> 政策 > 济南ui设计制作培训_大连网页设计公司_广州做seo公司_深圳海外推广

济南ui设计制作培训_大连网页设计公司_广州做seo公司_深圳海外推广

时间:2025/7/15 10:01:04来源:https://blog.csdn.net/2301_79722622/article/details/143273113 浏览次数:0次
济南ui设计制作培训_大连网页设计公司_广州做seo公司_深圳海外推广

vector

vector类似于数组

遍历

这里的遍历跟string那里的遍历是一样的

1.auto(范围for)
2.迭代器遍历
3.operator

void vector_test1()
{vector<int> v;vector<int> v1(10, 1);//初始化10个都是1的变量vector<int> v3(++v1.begin(), --v1.end());// 让迭代器begin+1,end-1,所以打印时会少两个数//operator[] 遍历for (int i = 0; i < v1.size(); ++i){cout << v1[i] << " ";}cout << endl;//auto 遍历for (auto a : v3){cout << a << " ";}cout << endl;//迭代器 遍历vector<int>::iterator it = v3.begin();for (int i = 0; i < v3.size(); ++i){cout << *it << " ";}cout << endl;
}

vector的扩容与缩容机制

扩容的代码

void TestVectorExpand()
{size_t sz;vector<int> v;//v.reserve(100);如果知道要扩容100个数,那么就预留100个数的空间sz = v.capacity();cout << "capacity changed: " << sz << '\n';cout << "making v grow:\n";for (int i = 0; i < 100; ++i){v.push_back(i);if (sz != v.capacity()){sz = v.capacity();cout << "capacity changed: " << sz << '\n';}}
}

vs2022下是1.5倍的扩容:
在这里插入图片描述
Linux下是2倍的扩容:
在这里插入图片描述
在这里插入图片描述
reserve函数最少开存n个数字的大小,可能会大于n个
vector的reserve是不缩容的,而string的reserve是有可能缩容的(在vs下不缩容,在linux下缩容)

验证vs下是否要缩容:

void vector_test2()
{vector<int> v(10, 1);v.reserve(20);cout << v.size() << endl;cout << v.capacity() << endl;v.reserve(15);cout << v.size() << endl;cout << v.capacity() << endl;v.reserve(5);cout << v.size() << endl;cout << v.capacity() << endl;
}

很显然是不缩容的
在这里插入图片描述
并且Linux下也是不缩容的
在这里插入图片描述

resize

n < size,删除数据,保留前n个数据
size < n < capacity,这里会增加n-size个数据,并且可能会缩容
n > capacity,会插入数据,你给了数据,就插入你给的数据,没给数据就插入缺省值,并且会扩容(2*n)

在这里插入图片描述

在这里插入图片描述

void vector_test3()
{vector<int> v(10, 1);v.reserve(20);cout << v.size() << endl;//10cout << v.capacity() << endl;//20v.resize(15,2);cout << v.size() << endl;//15cout << v.capacity() << endl;//20v.resize(25,3);cout << v.size() << endl;//25cout << v.capacity() << endl;//30v.resize(5);cout << v.size() << endl;//5cout << v.capacity() << endl;//30
}

insert + push_back+erase

vector中的insert只支持迭代器的
push_back尾插
erase删除pos位置的数据,也可以删除任意位置的数据,直接+n

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

void vector_test4()
{vector<int> v(10, 1);v.push_back(2);v.insert(v.begin(), 20);v.insert(v.begin() + 3, 10);for (auto a : v){cout << a << " ";}cout << endl;
}

流插入(cout)和流提取(cin)

vector不支持流插入和流提取
但vector自己实现的流插入和流提取很简单

void vector_test5()
{vector<int> v(5, 0);// 流插入for (size_t i = 0; i < 5; i++){cin >> v[i];}// 流提取for (auto e : v){cout << e << " ";}cout << endl;
}

vector不能代替string,因为vector没有 \0,还有许多其它原因,send(c_str()); 在传文件的时候要c_str(),并且要兼容C语言

void vector_test6()
{ vector<string> v;string s("hello world");v.push_back(s);v.push_back("yyyyyy");// 将 const char* 类型强转为string类型// ch不改变用const,减少拷贝用引用,因为v的元素是string类型的for (const auto& ch : v){cout << ch << " ";}cout << endl;// 10*5vector<int> v1(5, 1);vector<vector<int>> vv(10, v1);vv[1][2] = 2;// 定义10行5列的数组,类型于二维数组,但是是两个operator[]的使用
}
关键字:济南ui设计制作培训_大连网页设计公司_广州做seo公司_深圳海外推广

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: