我正在使用Collatz 猜想进行数学公平项目,我想制作一个反向图,你可以在维基百科上找到,尽管我发现我在代码中的某个地方搞砸了并且它没有显示所有反向值(例如,它会从数组中找到一个奇数,然后是相同的值 *2,但不会超过该值)。
#import "numberCreator.h"
@implementation numberCreator
@synthesize levels, nextX, nextY, numbers;
- (id)init
{
self = [super init];
if (self) {
numbers = [[NSMutableArray alloc]initWithCapacity:1000];//gives the array an estamated cap.
currentLevel = [[NSMutableArray alloc]initWithCapacity:25];
nextLevel = [[NSMutableArray alloc]initWithCapacity:25];
checkNumbers = [[NSMutableSet alloc]init];
}
return self;
}
//Creates all of the needed numbers in the reverce Collatz Web
- (void) create{
[currentLevel addObject:[NSNumber numberWithInt:1]];
[numbers addObject:[NSNumber numberWithInt:1]];
[numbers addObject:[NSNumber numberWithInt:0]];
[numbers addObject:[NSNumber numberWithInt:0]];
[checkNumbers addObject:[NSNumber numberWithInt:1]];
for(int x; x < levels; x++){
for(int y; y < [currentLevel count]; y++){
if([checkNumbers containsObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]floatValue]*2]]){}
else{
[checkNumbers addObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]intValue]*2]];
[numbers addObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]intValue]*2]];
[numbers addObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]intValue]]];//The array is set like Number, Parent, level
[numbers addObject:[NSNumber numberWithInt:x+1]];
[nextLevel addObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]intValue]*2]];
if((y-1)/3%2==1){
if([checkNumbers containsObject:[NSNumber numberWithInt:([[currentLevel objectAtIndex:y]floatValue]-1)/3]]){}
else{
[checkNumbers addObject:[NSNumber numberWithInt:([[currentLevel objectAtIndex:y]intValue]-1)/3]];
[numbers addObject:[NSNumber numberWithInt:([[currentLevel objectAtIndex:y]intValue]-1)/3]];
[numbers addObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]intValue]]];
[numbers addObject:[NSNumber numberWithInt:x+1]];
[nextLevel addObject:[NSNumber numberWithInt:[[currentLevel objectAtIndex:y]intValue]*2]];
}
}else{}
}
}
[currentLevel removeAllObjects];
for(int y; y < [nextLevel count]; y++){
[currentLevel addObject:[nextLevel objectAtIndex:y]];
}
[nextLevel removeAllObjects];
}
for(int x; x < [numbers count]; x++){
NSLog(@"%i", [[numbers objectAtIndex:x]intValue]);
}
}
@end