Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Порядок работы программы.





1. Проводим инициализацию графа.

 

_graph = [[Graph alloc] init];

 

2. После того, как пользователь кликнет по кнопке «Start», выполняется следующее действие:

 

- (IBAction)startButtonPressed:(id)sender

{

NSLog(@"Start button pressed");

[self dijkstra];

}

 

Из которого вызывается метод dijkstra.

 

3. Метод dijkstra реализует работу алгоритма Дейкстры.

 

- (void)dijkstra {

NSMutableArray *unVisited = [[NSMutableArray alloc] initWithCapacity:[self.graph.nodes count]];

NSMutableArray *distance = [[NSMutableArray alloc] initWithCapacity:[self.graph.nodes count]];

NSMutableArray *previous = [[NSMutableArray alloc] initWithCapacity:[self.graph.nodes count]];

 

// Стартовая вершина ("S")

Node *startNode = self.canvas.start;

// Конечная вершина ("T")

Node *endNode = self.canvas.end;

 

for (Node *node in self.graph.nodes) {

[distance addObject:[NSNumber numberWithFloat:INFINITY]];

[previous addObject:startNode];

}

 

 

[distance replaceObjectAtIndex:[self indexOfNode:startNode] withObject:[NSNumber numberWithInt:0]];

[unVisited addObjectsFromArray:self.graph.nodes];

 

 

while ([unVisited count]!= 0) {

 

Node *nodeWithMinPath = [unVisited objectAtIndex:0];

NSNumber *minNum = [distance objectAtIndex:[self indexOfNode:nodeWithMinPath]];

for (Node *node in unVisited) {

if ([minNum floatValue] > [[distance objectAtIndex:[self indexOfNode:node]] floatValue]) {

minNum = [distance objectAtIndex:[self indexOfNode:node]];

nodeWithMinPath = node;

}

}

 

[unVisited removeObject:nodeWithMinPath];

 

if ([[distance objectAtIndex:[self indexOfNode:nodeWithMinPath]] floatValue] == INFINITY)

break;

 

for (Path *pathToFriend in nodeWithMinPath.pathToFriends) {

if ([unVisited containsObject:pathToFriend.connectedNode] == NO) {

continue;

}

 

 

NSNumber *alt = [NSNumber numberWithFloat:[[distance objectAtIndex:[self indexOfNode:nodeWithMinPath]] floatValue] + [[NSNumber numberWithInteger:pathToFriend.edgeCost] floatValue]];

 

if ([alt floatValue] < [[distance objectAtIndex:[self indexOfNode:pathToFriend.connectedNode]] floatValue]) {

[distance replaceObjectAtIndex:[self indexOfNode:pathToFriend.connectedNode] withObject:alt];

[previous replaceObjectAtIndex:[self indexOfNode:pathToFriend.connectedNode] withObject:nodeWithMinPath];

}

}

}

 

// Show result

NSMutableArray *reverseResult = [[NSMutableArray alloc] init];

 

Node *node = endNode;

[reverseResult addObject:node];

while (node!= startNode) {

node = [previous objectAtIndex:[self indexOfNode:node]];

[reverseResult addObject:node];

}

 

NSString *result = @"Path: ";

for (int i = (int)[reverseResult count]-1; i >= 0; i--) {

Node *foo = [reverseResult objectAtIndex:i];

NSLog(@"res: '%i'", foo.value);

result = [result stringByAppendingFormat:@"%i ", foo.value];

}

 

NSNumber *resultSum = [distance objectAtIndex:[self indexOfNode:endNode]];

NSLog(@"resultSum: %f", [resultSum floatValue]);

result = [result stringByAppendingFormat:@"\nShortest Path Cost: %f ", [resultSum floatValue]];

[self.resultLabel setStringValue:result];

}

 







Дата добавления: 2015-09-04; просмотров: 553. Нарушение авторских прав; Мы поможем в написании вашей работы!




Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...


Композиция из абстрактных геометрических фигур Данная композиция состоит из линий, штриховки, абстрактных геометрических форм...

Мелоксикам (Мовалис) Групповая принадлежность · Нестероидное противовоспалительное средство, преимущественно селективный обратимый ингибитор циклооксигеназы (ЦОГ-2)...

Менадиона натрия бисульфит (Викасол) Групповая принадлежность •Синтетический аналог витамина K, жирорастворимый, коагулянт...

Разновидности сальников для насосов и правильный уход за ними   Сальники, используемые в насосном оборудовании, служат для герметизации пространства образованного кожухом и рабочим валом, выходящим через корпус наружу...

Законы Генри, Дальтона, Сеченова. Применение этих законов при лечении кессонной болезни, лечении в барокамере и исследовании электролитного состава крови Закон Генри: Количество газа, растворенного при данной температуре в определенном объеме жидкости, при равновесии прямо пропорциональны давлению газа...

Ганглиоблокаторы. Классификация. Механизм действия. Фармакодинамика. Применение.Побочные эфффекты Никотинчувствительные холинорецепторы (н-холинорецепторы) в основном локализованы на постсинаптических мембранах в синапсах скелетной мускулатуры...

Шов первичный, первично отсроченный, вторичный (показания) В зависимости от времени и условий наложения выделяют швы: 1) первичные...

Studopedia.info - Студопедия - 2014-2025 год . (0.008 сек.) русская версия | украинская версия