I’ve seen a lot of examples of sorting a dictionary by keys, then getting the values, but how would I sort instead by values.
e.g.
{
blue:12;
red:50;
white:44;
}
I would want these sorted by number descending to:
{
red:50;
white:44;
blue:12
}
I tried getting a sorted nsarray of keys from which I could created the ordered nsarray but the result still seems unordered.
NSArray* sortedKeys = [stats keysSortedByValueUsingComparator:^(id first, id second) {
if ( first < second ) {
return (NSComparisonResult)NSOrderedAscending;
} else if ( first > second ) {
return (NSComparisonResult)NSOrderedDescending;
} else {
return (NSComparisonResult)NSOrderedSame;
}
}];
Conceptually a NSDictionary is unsorted, as said already by C0deH4cker.
If you need an order, you can either write the keys to an array (but you might have trouble with the array retaining it after the key was removed from the dictionary, but there are tutorials how to create a un-retaining array by using the CFArray) or NSSortedSet.
Or you can subclass NSDictionary — not very trivial, as NSDictionary is a class cluster. But luckily Matt shows in his fantastic blogpost “OrderedDictionary: Subclassing a Cocoa class cluster” how to use a little trick, a covered has-a relationship.
Note, that your code
wont do, what you want it to do, as you are applying C-operators to objects. Now their pointers will be ordered.
it should be something like
or if you want to order on scalars, that are wrappers as objects (ie NSNumber)