【二维vector删除前n行和前n列】

二维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;
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值