- 与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);
}
- 编写一个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