[lambda]How to use the member of placeholder in std algorithm?
data:image/s3,"s3://crabby-images/b9f0a/b9f0a1375eb990cb29736bd28c0a72099e0e9e12" alt=""
I have a struct: struct Coordinate { double x, y, z; }; There is no any operator definition for it. I want to sort a array of this struct with 3 elements by comparing the Z value, so: Coordinate coords[3]; ....... std::sort(coords, coords+3, _1 < _2); What should I write to replace "_1 < _2" here? How can I reference the Z member of _1 and _2? I hope I can sort this array without defining any new function. thanks!
data:image/s3,"s3://crabby-images/e0dea/e0deaef5932af38b638b6d1bd53c0537f8750b6b" alt=""
2009/2/27 钱晓明
I have a struct: struct Coordinate { double x, y, z; }; There is no any operator definition for it.
I want to sort a array of this struct with 3 elements by comparing the Z value, so: Coordinate coords[3]; ....... std::sort(coords, coords+3, _1 < _2); What should I write to replace "_1 < _2" here? How can I reference the Z member of _1 and _2? I hope I can sort this array without defining any new function.
bind(&Coordinate::z, _1) < bind(&Coordinate::z, _2) Roman Perepelitsa.
participants (2)
-
Roman Perepelitsa
-
钱晓明