二维vector删除前n行和前n列:
提示:这里简述项目相关背景:
例如:项目场景:删除一个嵌套二维vector<vector< int >> dataList中的前deleteNum行或者前deleteNum列
问题描述
例如:最开始尝试的是使用 algorithm库下的erase看函数,
//使用erase函数
for (int i = 0; i < deleteNum; i++)
{
dataList[i].erase(dataList[i].begin(),dataList[i].end());
}
提示:这里描述项目中遇到的问题:
在使用erase删除二维vector的某一行时需要注意:元素虽然删掉了,但是内存依然存在!
例如有二维vector :dataList[2][2],包含元素为[[1,2],[3,4]],比如我想删除第一行,使用erase方法删除之后dataList[0]依然存在,虽然dataList[0].size()输出为0,但是输出dataList.size()仍然是2,这说明dataList[0]实际没有因为没有元素而被释放,当然这样做也有好处,有利于后续添加数据。
解决方案:
提示:要想真正的删除二维数组中的前deleteNum行或者前deleteNum列可以新建一个二维vector来替代它。
提示:删除前deleteNum行:
新建一个中间vector,并按行遍历
注意:定义中间vector时需要确定中间vector大小
dataList_sortRow(dataList.size()-deleteNum,vector(dataList[0].size()))
//删除前deleteNum行
int deleteNum = 2;
vector<vector<int>> dataList_sortRow(dataList.size()-deleteNum,vector<int>(dataList[0].size()));
for (int i = deleteNum; i < dataList.size(); i++)
{
for (int j = 0; j < dataList[i].size(); j++)
{
dataList_sortRow[i - deleteNum][j] = dataList[i][j];
}
}
dataList = dataList_sortRow;
提示:删除前deleteNum列:
新建一个中间vector,并按列遍历
注意:定义中间vector时需要确定中间vector大小
vector<vector> dataList_sortCol(dataList.size(), vector(dataList[0].size()-deleteNum));
//删除前deleteNum列
int deleteNum = 2;
vector<vector<int>> dataList_sortCol(dataList.size(), vector<int>(dataList[0].size()-deleteNum));
for (int i = deleteNum; i < dataList[0].size(); i++)
{
for (int j = 0; j < dataList.size(); j++)
{
dataList_sortCol[j][i - deleteNum] = dataList[j][i];
}
}
dataList = dataList_sortCol;