1. stl vector基本概念 stl vector是一个动态数组,其内部实现采用连续的内存空间存储元素。vector中的每个元素都可以通过下标进行访问,且vector支持快速的随机访问。vector还支持在尾部添加/删除元素,并可以动态扩展/缩小内部空间以适应元素数量的变化。2. stl vector初始化 在使用stl vector之前,需要先进行初始化。
4,用指针模拟end ,对应代码里的test4 5,标准库函数std::begin,std::end,对应代码里的test5 6,ptrdiff_t和size_t,ptrdiff是数组下标相加减的值的类型,size_t是数组下标的类型,对应代码里的test6 7,数组的下标可以是负值,标准库的string,vector的下标也可以是负值,对应代码里的test7 8,用数组初始化vector,注...
这个例子中,我们声明了一个数组vector,并为其初始化了数值。而后我们又声明了一个指针p,且将vector数组的首地址赋值给了p,实际上,这个时候对于指针p指向的地址的内容的改变,就会直接表现在数组vector中了。仔细查看这份示例代码都做了什么,推理一下程序运行后会有什么样的输出?可以看到,对于指针p的取值以及解...
我们通过下面这段代码来了解一下std::vector的动态扩容过程。 #include<iostream>#include<vector>intmain(){std::vector<int>vec;intcapacity=-1;std::cout<<"size: "<<vec.size()<<" capacity: "<<vec.capacity()<<std::endl;for(inti=0;i<500;i++){vec.push_back(i);if(capacity!=vec.capacit...
在C语言中,我们可以使用动态内存分配来定义一个类似于vector的数组。首先,我们需要定义一个结构体来表示这个数组,其中包含一个指向实际数据的指针和当前数组的长度和容量。typedef struct { int* data; int size; int capacity; } Vector; 复制代码接下来,我们可以定义一些函数来对这个数组进行操作。初始化函数:用于...
由于我们使用向量作为指针数组,让我们完全摆脱指针 std::vector<std::vector<int> > v; v.resize(10); v[2].resize(50); // allocate one array 然后像矩阵一样访问数组: v[3][40] = 14; 更进一步,一种初始化所有行的方法,使用 C++11,最后制作一个 10x50 int 矩阵(但如果我们愿意,大小也可以在...
初始化二维数组 vector<vector <int> > ivec(m ,vector<int>(n,0)); //m*n的二维vector,所有元素为0 C++中用new动态创建二维数组的格式一般是这样: TYPE (*p)[N] =newTYPE [][N]; 其中,TYPE是某种类型,N是二维数组的列数。采用这种格式,列数必须指出,而行数无需指定。在这里,p的类型是TYPE*[N...
从string返回一个C风格字符串,即返回一个指针指向以空字符结束的字符数组。 c_str返回的数组不保证一直有效,可能后续操作s的值改变之后,之前返回的数组就失去了效用。想一直使用,最好重新拷贝一份。 用数组初始化vector对象 vector<int> ivec(begin(int_arr), end(int_arr)); ...
不要忘记,您可以将指针视为迭代器:
在这段代码中,我们首先定义了一个结构体`Vector`,表示向量数据结构。然后,我们实现了三个函数:`init_vector`用来初始化向量,`push_back`用来向向量中添加元素,`print_vector`用来打印向量中的所有元素。最后,在`main`函数中,我们创建了一个整型向量,并向其中添加了20个元素,最后打印了向量的内容。