NSArray内の(小さな)NSNumberのセットの中央値を計算しようとしています。NSArray内のすべてのオブジェクトはNSNumberです。
これが私が試していることですが、機能していません:
NSNumber *median = [smallNSArray valueForKeyPath:@"@median.floatValue"];
NSArray内の(小さな)NSNumberのセットの中央値を計算しようとしています。NSArray内のすべてのオブジェクトはNSNumberです。
これが私が試していることですが、機能していません:
NSNumber *median = [smallNSArray valueForKeyPath:@"@median.floatValue"];
NSArray *sorted = [smallNSArray sortedArrayUsingSelector:@selector(compare:)]; // Sort the array by value
NSUInteger middle = [sorted count] / 2; // Find the index of the middle element
NSNumber *median = [sorted objectAtIndex:middle]; // Get the middle element
あなたはより空想を得ることができます。たとえば、偶数のセットの中央値は、技術的には真ん中の2つの数値の平均です。これを次のカテゴリのきちんとした1行のメソッドにまとめることもできますNSArray
。
@interface NSArray (Statistics)
- (id)median;
@end
@implementation NSArray (Statistics)
- (id)median
{
return [[self sortedArrayUsingSelector:@selector(compare:)] objectAtIndex:[self count] / 2];
}
@end
この関数が通常とは異なる必要がある場合は、奇数と偶数の両方の要素で機能するNSArrayのカテゴリメソッドを次に示します。
- (float)median {
if (self.count == 1) return [self[0] floatValue];
float result = 0;
NSUInteger middle;
NSArray * sorted = [self sortedArrayUsingSelector:@selector(compare:)];
if (self.count % 2 != 0) { //odd number of members
middle = (sorted.count / 2);
result = [[sorted objectAtIndex:middle] floatValue];
}
else {
middle = (sorted.count / 2) - 1;
result = [[@[[sorted objectAtIndex:middle], [sorted objectAtIndex:middle + 1]] valueForKeyPath:@"@avg.self"] floatValue];
}
return result;
}
NSArray * singleElement = @[@1];
NSArray * oddNumberOfElements = @[@3, @5, @7, @12, @13, @14, @19, @20, @21, @22, @23, @29, @39, @40, @56];
NSArray * evenNumberOfElements = @[@3, @5, @7, @12, @13, @14, @19, @20, @21, @22, @23, @29, @40, @56];
NSLog(
@"oddNumberOfElements: %f, evenNumberOfElements: %f singleElement: %f",
[oddNumberOfElements median], [evenNumberOfElements median], [singleElement median]
);
//oddNumberOfElements: 20.000000, evenNumberOfElements: 19.500000 singleElement: 1.000000
Swiftエクステンション
extension Array where Element: Comparable {
var median: Element {
return self.sort(<)[self.count / 2]
}
}