|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
|
Использование алгоритма поиска с возвратом26.01.2013, 18:06. Показов 2180. Ответов 11
Метки нет (Все метки)
Добрый день, помогите пожалуйста решить проблему. Очень долго не могу составить правильную функцию для работы программы( Надо написать псевдокод для такой программы: (задача во вложении).
Я написал такой код: STAN(min:number=0(минимальное время), temp:array[](временной массив), diffs:array[][](таблица со временем, diffs[a][b] - время перемещения между станциями a и b), station_index (Индекс станции), s1,s2 (пользовательское значение - станция отправки и станция прибытия)); function main():void //Главная функция { повторяем (i = 0; i < n; i++) //Бежим по всем станциям { temp.push(diffs[s1][i] + diffs[i][s2]);//Забиваем во временный массив кандидата на минимальное время если (isMinimal(diffs[s1][i] + diffs[i][s2]))//Если оно на данном этапе действительно минимально { min = diffs[s1][i] + diffs[i][s2];//Забиваем как минимальное station_index = i;//Сохраняем индекс станции } } вывод (min, station_index);//Выводим время и станцию, через которую ехать } function isMinimal(value:Number):Boolean //Возвращет, является ли value наименьшим во временном массиве { повторяем ( i = 0; i < temp.length; i++)//Бежим по временному массиву { если (value > temp[i]) return false; //Если вдруг value больше какого-то элемента, значит оно не минимально } return true; } Проблема в том, что эта программа не учитывает того, что между станциями А и В может быть несколько связующих станций и может быть такой вариант, что такого пути нет. Для этого надо использовать поиск с возвратом, но я уже раз 5 показывал свои варианты преподу и он все отметает, говорит что ваще не то. Ошибка начинается со строки temp.push(diffs[s1][i] + diffs[i][s2]) (нужно написать нужную функцию,но я не знаю какую) Помогите кто чем может и какие варианты можно попробовать.
0
|
|
| 26.01.2013, 18:06 | |
|
Ответы с готовыми решениями:
11
Алгоритм поиска с возвратом Реализуйте на практике 2 алгоритма поиска и 2 алгоритма сортировки. Результаты сравните |
|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
|
| 30.01.2013, 18:47 [ТС] | |
|
Люююди, откликнитесь кто-нибудь, пожалуйста!
0
|
|
|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
|
| 04.02.2013, 09:22 [ТС] | |
|
Задание: Некоторая железнодорожная компания обслуживает n станций S1, S2, ..., Sn. Она предполагает установить информационные терминалы, с которых клиент может вводить название своей станции отправления Sa и станции назначения Sb, а ему должно выдавать расписание поездов, обеспечивающих минимальное время поездки. Написать алгоритм, который позволит это осуществить. Расписание представлено данными некоторой структуры, где перечисляется время отправления (прибытия) всех поездов (не между всеми станциями есть прямое сообщение). (Указание: использовать "поиск с возвратом")
0
|
|
| 04.02.2013, 13:34 | ||||||
|
Задайте сам граф, напр матрицей смежности. Напр первая строка
-1 2 -1 3 Значит из первой станции можно приехать во 2-ю за 2 часа или в 4-ю за 3 часа. А дальше просто крутите рекурсию
0
|
||||||
|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
|
| 04.02.2013, 16:44 [ТС] | |
|
-1 2 -1 3 - не очень понимаю, почему -1 задана станция?
0
|
|
|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
|
| 04.02.2013, 19:20 [ТС] | |
|
// нашли путь, проверяем и запоминаем если лучший (сделаете сами)
то есть создаем одномерный массив, в который будут записываться -1 2 -1 3 и прочие станции?
0
|
|
| 04.02.2013, 19:35 | |||||||
0
|
|||||||
|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
|
| 06.02.2013, 15:47 [ТС] | |
|
int j;
for (ij = 0; j < num; ++j) if (i == path[j]) break; if (j < num) continue; не могу понять, почему в цикле for (ij = 0; j < num; ++j) , ij=0 Добавлено через 11 минут i int bestPath[N]; int numBest = 0; int bestLen = -1; const int firstStation = 2; // исходная станция (индекс) const int lastStation = 5; // конечная (индекс) и почему такие числа приравниваются? не могу понять.
0
|
|
| 06.02.2013, 16:28 | ||
|
Влад, что-то совсем мрачно - видать гульки на уме а не программирование Больше на вопросы типа "ничего не понимаю" отвечать не буду
0
|
||
|
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
|
||||||
| 06.02.2013, 18:15 [ТС] | ||||||
|
Спасибо. Просто я задачу саму понять не мог в плане того, как должен выглядеть конечный ответ.
Добавлено через 1 минуту В общем вот:
0
|
||||||
| 06.02.2013, 18:15 | |
|
Помогаю со студенческими работами здесь
12
Использование хранимой процедуры с возвратом состояния Реализовать программу, осуществляющую поиск выхода из лабиринта методом поиска с возвратом. Реализовать программу, осуществляющую поиск выхода из лабиринта методом поиска с возвратом. Найти точку минимума функции методом случайного поиска с возвратом и наилучшей пробы Заданное множество (1,2,3,4). Вывести все перестановки заданного множества методом поиска с возвратом Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога
Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
|