一、背景
新建一个关于c++标准库容器的文章,记录常用容器的常用方法。
二、导入
首先是有牛客上的一道题目引入的
做牛客的一道题目:
1、以下代码执行后,it的数据为()
1 | std::list temp; |
---|---|
2 | std::list<int >::iterator it = temp.begin(); |
3 | it = --it; |
A、未知
B、temp.end()
C、异常
D、NULL
这个题目有点蒙,我选的是A,然后我不确定答案,所以在codeblock上想跑一下看看,突然发现我连STL迭代器都不太会写,真尴尬,记录一下
三、List
1.示例代码
代码如下:
#include <stdio.h>
#define ADD(x) x + x
#include <List>main() {int m = 1, n = 2, k = 3, sum;sum = ADD(m + n) * k;printf("sum = %d\n", sum);std::list<int> temp;for(int i = 0; i < 5; i++){temp.push_back(i);}std::list<int>::iterator it = temp.begin();it = it--;for(it; it != temp.end(); it++){printf("%d ",(*it));}
}//正常打印
//vector同理
2.读入数据
代码如下(示例):
data = pd.read_csv('https://labfile.oss.aliyuncs.com/courses/1283/adult.data.csv')
print(data.head())
四、vector:
1.1 取vector数据前200个元素
比如vector1中有数据,下面将取出vector1中的数据
if(vector.size > 200)
{vector2(vector1.begin(), vector1.begin()+200);
}
上面存在问题就是当vector2还被下面的条件使用,而vector2是局部变量
if(vector.size > 200)
{vector2.assign(vector1.begin(), vector1.begin()+200);
}
1.2 erase的使用
看traffic代码的时候有erase的使用。但是这个方法不是很熟。所以写了个测试代码
#ifdef VECTOR_ERASE_TEST
void eraseTest()
{std::vector<int> vec;vec.push_back(1);vec.push_back(2);vec.push_back(3);vec.push_back(4);vec.push_back(5);for(int i = 0; i < vec.size(); i++){std::cout << vec[i] << std::endl;}vec.erase(vec.begin() + 2);for(int i = 0; i < vec.size(); i++){std::cout << vec[i] << std::endl;}
}
#endif
打印结果如下
12345
1245
所以erase方法是删除vector中的成员。
实际在调试过程中,我本来以为能看到:比如我写成vec.begin() + 2,是删除第三个元素,我以为能看到vector[3]会消失,实际上并没有看到,我在traffic代码中还以为我理解错这个方法的意思了。实际上总数会少一个,剩下的成员还是1-4。这边记录一下。
实际上我在查资料的时候还看到需要iter++使用注意点,包括我以前看到的某个STL插入会使这个STL失效。这边暂不深究。
1.3 vector::clear()
vector的clear方法是删除vector中的元素。
五、总结
未完待续