From 8a8af365709122fa63c7e50c746ecba7580dbea3 Mon Sep 17 00:00:00 2001 From: rick Date: Fri, 26 Mar 2021 16:53:45 +0100 Subject: [PATCH] =?UTF-8?q?Ajout=20d=C3=A9but=20partie=202=20(bugg=C3=A9)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- jour14/jour14.m | 9 ++++-- jour14/raindeer.h | 9 +++++- jour14/raindeer.m | 28 ++++++++++++++++++- jour14/troupeau.h | 15 ++++++++++ jour14/troupeau.m | 71 +++++++++++++++++++++++++++++++++++++++++++++++ 5 files changed, 128 insertions(+), 4 deletions(-) create mode 100644 jour14/troupeau.h create mode 100644 jour14/troupeau.m diff --git a/jour14/jour14.m b/jour14/jour14.m index a2d52c1..3d186ee 100644 --- a/jour14/jour14.m +++ b/jour14/jour14.m @@ -1,4 +1,5 @@ #import "raindeer.h" +#import "troupeau.h" #import int main() @@ -12,6 +13,7 @@ int main() error:&err]; NSArray *lines = [contentFile componentsSeparatedByString:@"\n"]; NSMutableArray *listDeer = [[NSMutableArray alloc] init]; + Troupeau *troupeau = [[Troupeau alloc] init]; for (NSString *tmp in lines) { @@ -22,10 +24,11 @@ int main() zatSpeed:[[parsedSpace objectAtIndex:3] integerValue] boostTime:[[parsedSpace objectAtIndex:6] integerValue] LunchTime:[[parsedSpace objectAtIndex:13] integerValue]]; - [listDeer addObject:rd]; + [troupeau newDeer:rd]; } } + /* int ret = 0; int tmp = 0; for (Raindeer *rd in listDeer) @@ -35,7 +38,9 @@ int main() ret = tmp; [rd release]; } - NSLog(@"le résultat est : %d", ret); + */ + NSLog(@"le résultat est : %d", [troupeau courseUne:1000]); + NSLog(@"le résultat est : %d", [troupeau courseDeux:1000]); //finir le main par ça [contentFile release]; diff --git a/jour14/raindeer.h b/jour14/raindeer.h index 103b76c..3833b74 100644 --- a/jour14/raindeer.h +++ b/jour14/raindeer.h @@ -6,14 +6,21 @@ int speed; int boostTime; int pause; + int points; + + int cooldown; + int hypervitesse; + int distance; } // permet de générer des setters et getter selon des attributs // ici retain, nonatomic et assign @property (retain, nonatomic) NSString *name; -@property (assign) int speed, boostTime, pause; +@property (assign) int speed, boostTime, pause, points, cooldown, hypervitesse, distance; + (id) initWithName:(NSString*)name zatSpeed:(int)speed boostTime:(int)timeSpeed LunchTime:(int)pause; - (int) calculDistance:(int)time; +- (int) updateDistance; +- (void) updatePoints; @end diff --git a/jour14/raindeer.m b/jour14/raindeer.m index 177475f..7de27f8 100644 --- a/jour14/raindeer.m +++ b/jour14/raindeer.m @@ -4,7 +4,7 @@ @implementation Raindeer // permet de créer les getters et setters à partir de property -@synthesize name, speed, boostTime, pause; +@synthesize name, speed, boostTime, pause, points, cooldown, hypervitesse, distance; + (id) initWithName:(NSString*)name zatSpeed:(int)speed boostTime:(int)boostTime LunchTime:(int)pause { @@ -15,6 +15,10 @@ new.speed = speed; new.boostTime = boostTime; new.pause = pause; + new.points = 0; + new.cooldown = 0; + new.hypervitesse = boostTime; + new.distance = 0; } return new; } @@ -31,6 +35,28 @@ return ret; } +- (int) updateDistance +{ + if (cooldown > 0) + cooldown--; + if (cooldown == 0) + hypervitesse = boostTime; + else + { + distance += speed; + hypervitesse--; + if (hypervitesse == 0) + cooldown = pause; + } + + return distance; +} + +- (void) updatePoints +{ + points++; +} + - (void) dealloc { [name release]; diff --git a/jour14/troupeau.h b/jour14/troupeau.h new file mode 100644 index 0000000..e25bd9d --- /dev/null +++ b/jour14/troupeau.h @@ -0,0 +1,15 @@ +#import "raindeer.h" +#import + +@interface Troupeau : NSObject +{ + NSMutableArray *troupeau; + NSSortDescriptor *recetteTri; +} + +- (id) init; +- (void) newDeer:(Raindeer*)rd; +- (int) courseUne:(int)time; +- (int) courseDeux:(int)time; + +@end diff --git a/jour14/troupeau.m b/jour14/troupeau.m new file mode 100644 index 0000000..684f09a --- /dev/null +++ b/jour14/troupeau.m @@ -0,0 +1,71 @@ +#import "troupeau.h" +#import "raindeer.h" + +@implementation Troupeau + +- (id) init +{ + self = [super init]; + if (self) + { + recetteTri = [[NSSortDescriptor alloc] initWithKey:@"distance" + ascending:YES]; + troupeau = [[NSMutableArray alloc] init]; + } + return self; +} + +- (void) newDeer:(Raindeer*)rd +{ + [troupeau addObject:rd]; +} + +- (int) courseUne:(int)time +{ + int ret = 0, tmp = 0; + for (Raindeer *rd in troupeau) + { + tmp = [rd calculDistance:time]; + if (tmp > ret) + ret = tmp; + } + return ret; +} + +- (int) courseDeux:(int)time +{ + int ret = 0; + while (time > 0) + { + for (Raindeer *rd in troupeau) + { + int t = [rd updateDistance]; + } + NSArray *tmp = [NSArray arrayWithObject:recetteTri]; + NSArray *sortedRank = [troupeau sortedArrayUsingDescriptors:tmp]; + [[sortedRank firstObject] updatePoints]; + NSLog(@"%d", [[sortedRank firstObject] points]); + NSLog(@"Rennes : %@ pour une distance de %d", [[troupeau firstObject] name], [[troupeau firstObject] distance]); + // copier dans le troupeau le tableau trié + time--; + } + NSSortDescriptor *tt = [[NSSortDescriptor alloc] initWithKey:@"points" + ascending:YES]; + NSArray *tmpp = [NSArray arrayWithObject:tt]; + NSArray *sortedPonits = [troupeau sortedArrayUsingDescriptors:tmpp]; + NSLog(@"%d", [[sortedPonits firstObject] points]); + ret = [[sortedPonits firstObject] points]; + + return ret; +} + +- (void) dealloc +{ + for (Raindeer *rd in troupeau) + [rd dealloc]; + [troupeau release]; + [recetteTri release]; + [super dealloc]; +} + +@end