Sha256: 8b8379e31a0852d10013a3aeb9b7146c507a9ca7032f46d14fb7685047e57cfa

Contents?: true

Size: 825 Bytes

Versions: 249

Compression:

Stored size: 825 Bytes

Contents

#import "SieveExample.h"

@implementation Sieve

+ (NSArray<NSNumber *> *)primesUpTo:(int)limit {
    if (limit < 2) {
        return @[];
    }
    
    NSMutableArray<NSNumber *> *numbers = [[NSMutableArray alloc] init];
    
    for (int i = 2; i <= limit; i++) {
        [numbers addObject:@(i)];
    }
    
    NSMutableArray<NSNumber *> *primes = [[NSMutableArray alloc] init];
    
    while (numbers.count > 0) {
        NSNumber *target = [numbers objectAtIndex:0];
        [numbers removeObjectAtIndex:0];
        [primes addObject:target];
        NSPredicate *predicate = [NSPredicate predicateWithBlock:^BOOL(NSNumber *number, NSDictionary *bindings) {
            return number.intValue % target.intValue != 0;
        }];
        [numbers filterUsingPredicate:predicate];
    }
    
    return primes;
}

@end

Version data entries

249 entries across 249 versions & 1 rubygems

Version Path
trackler-2.2.1.180 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.179 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.178 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.177 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.176 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.175 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.174 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.173 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.172 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.171 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.170 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.169 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.167 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.166 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.165 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.164 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.163 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.162 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.161 tracks/objective-c/exercises/sieve/SieveExample.m
trackler-2.2.1.160 tracks/objective-c/exercises/sieve/SieveExample.m