对包含 pair<x,y 的向量进行排序>
Sorting a vector that contains pair<x,y>
我在某处看到过一个代码,其中一个人做了这样的事情
#define pp pair<int,int>
int main()
{
int n,i;
scanf("%d",&n);
vector<pp> G;
for(i=0;i<n;i++)
{
int x,y;
scanf("%d%d",&x,&y);
G.push_back(pp(x+y,x-y));
}
sort(G.begin(),G.end());
我想知道这里是如何完成排序的。我的意思是说在包含对的向量中执行什么参数排序。
sort
函数根据比较函数(定义顺序)进行排序。人们可能想要指定使用哪个omparaison,但是如果未指定比较函数(如您的情况),则sort
使用defet作为所考虑对象的<
运算符
因此,在您的情况下,可以订购,因为比较运算符已重载std::pair
。
这些操作符的行为描述如下 http://en.cppreference.com/w/cpp/utility/pair/operator_cmp:
因此,在排序时,将调用std::pair
类上的<
运算符,并且您的对将按字典顺序排序
(0,1) < (0,2) < (1,0) < (1,2) < (2,7)
检查此链接:http://www.cplusplus.com/reference/utility/pair/operators/
类似地,运算符 <、>、<= 和>= 对由成员第一和第二形成的序列执行字典顺序比较。
所以,a < b
意味着(a.first < b.first) || (a.first == b.first && a.second < b.second)
相关文章:
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- EASTL矢量<向量<int>>连续的
- 为什么将此对向量&lt; map&lt; int,int&gt;&gt;中的地图进行更新.失败
- 如何加入向量&lt; int&gt;到C 中的单个INT
- 将图像加载到Mat-vvector<向量<垫子>>