NSArray子数组的NSIndexSet排序

时间:2016-01-24 20:39:14

标签: ios sorting nsarray nsindexset

假设我有NSIndexSet个数组索引。 我想对此NSIndexSet进行排序取决于NSArray

所以,假设我们有数组:

array = @[1,4,3,8,6,2,9];

和索引集

indexSet :  (2,4,5,6)

所以这个索引的“子数组”将是

subArray = @[3,6,2,9]

所以我想拥有的是:

I have :
indexSet : (2,4,5,6)
array = @[1,4,3,8,6,2,9];
return indexSet : (5,2,4,6) --> this are sorted indexes of "sub array".

如何实现这一目标?

1 个答案:

答案 0 :(得分:2)

你无法实现自己想要的目标。 NSIndexSet不会维护与索引本身顺序分开的订单。它始终按索引顺序排列。

您可以构建一个数字对象数组,并将其视为索引。

NSArray* array = /* ... */;
NSMutableArray* indexes = [[NSMutableArray alloc] init];
[indexSet enumerateIndexesUsingBlock:^(NSUInteger idx, BOOL *stop){
    [indexes addObject:@(idx)];
}];
[indexes sortUsingComparator:^NSComparisonResult(NSNumber* obj1, NSNumber* obj2){
    NSUInteger index1 = obj1.unsignedIntegerValue;
    NSUInteger index2 = obj2.unsignedIntegerValue;
    id element1 = array[index1];
    id element2 = array[index2];
    return [element1 compare:element2];
}];