How do I define a secondary ordering to the Heap::Simple interface in Perl?
Share
Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.
Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.
Lost your password? Please enter your email address. You will receive a link and will create a new password via email.
Please briefly explain why you feel this question should be reported.
Please briefly explain why you feel this answer should be reported.
Please briefly explain why you feel this user should be reported.
The documentation states that the constructor takes a code reference to define
the order, so you can specify any sort method you like:
By “secondary ordering” I assume you mean that a second comparison is used if
the first one shows the values to be equal. Let’s say the first comparison is
of values found via the “method1” method, and the second comparison is of
values from “method2”. So, if by method1 the values are different, return
that result, and otherwise fall back to method2:
If method1 and method2 return strings instead of numeric values, simply use
the
cmpoperator instead of<=>. You can use anything you like, as longas the operator returns the right values. Most sort functions like using the
values -1, 0 and 1 to indicate whether value1 is less than, equal to, or
greater than value2, but this module likes 1 to mean val1 < val2, so after
gathering the -1, 0, 1 result, one then returns 1 if the result is -1 (where
value1 is less than value2).