99网
您的当前位置:首页vector定义的二维数组的按列排序的方法

vector定义的二维数组的按列排序的方法

来源:99网
void do_sth(vector<vector<int>>&vec)//有些编译器>>之间要有空格
//&可避免直接复制数组,提高编译效率
{
	auto cmp = [](vector<int>& a, vector<int>&b)
		{return a[0]<b[0];//表示按第0列从小到大进行排序};
	sort(vec.begin(),vec.end(),cmp);
}
  1. 编写一个compare函数
bool compare(vector<int>&a,vector<int>&b)
	{return a[0]<b[0];}
void do_sth(vector<vector<int>>&vec)
{
	...
	sort(vec.begin(),vec.end(),compare);
	...
}

如果没通过可将函数头改成
static bool compare()

还有一种方法是将vector<vector<int>>vec替换成vector<pair<int,int>>vec,不过我暂时还没搞懂具体操作QAQ

因篇幅问题不能全部显示,请点此查看更多更全内容