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

  1. 与sort一起写在同一个函数里面
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

发布了109 篇原创文章 · 获赞 9 · 访问量 1万+

猜你喜欢

转载自blog.csdn.net/qq_43661234/article/details/105133856