Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
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
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.01.2013, 18:06
Ответы с готовыми решениями:

Пояснить суть алгоритма поиска с возвратом
Здравствуйте) Ни как не могу понять &quot;смысл&quot; алгоритма с возвратом... :( Какая у него функция? может кто подскажет...

Алгоритм поиска с возвратом
Задана квадратная матрица размером NxN, которая содержит целые числа от 0 до 6. Костью домино можно накрыть две соседние ячейки матрицы...

Реализуйте на практике 2 алгоритма поиска и 2 алгоритма сортировки. Результаты сравните
Всем привет! Я в С++ абсолютный чайнег, поэтому за дебильные вопросы сапогами не пинайте))) в общем есть код работающий в борланде....

11
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
30.01.2013, 18:47  [ТС]
Люююди, откликнитесь кто-нибудь, пожалуйста!
0
Почетный модератор
12274 / 5340 / 268
Регистрация: 05.04.2011
Сообщений: 14,086
Записей в блоге: 2
03.02.2013, 11:26
Влад000, перепечатайте задание на форум.
0
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
04.02.2013, 09:22  [ТС]
Задание: Некоторая железнодорожная компания обслуживает n станций S1, S2, ..., Sn. Она предполагает установить информационные терминалы, с которых клиент может вводить название своей станции отправления Sa и станции назначения Sb, а ему должно выдавать расписание поездов, обеспечивающих минимальное время поездки. Написать алгоритм, который позволит это осуществить. Расписание представлено данными некоторой структуры, где перечисляется время отправления (прибытия) всех поездов (не между всеми станциями есть прямое сообщение). (Указание: использовать "поиск с возвратом")
0
1968 / 824 / 115
Регистрация: 01.10.2012
Сообщений: 4,870
Записей в блоге: 2
04.02.2013, 13:34
Задайте сам граф, напр матрицей смежности. Напр первая строка

-1 2 -1 3

Значит из первой станции можно приехать во 2-ю за 2 часа или в 4-ю за 3 часа. А дальше просто крутите рекурсию

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
void Step(
 int * path,   // пройденный путь
 int num,  // число пройденных станций
 int len )     // пройденное время 
{
 int row = path[num - 1];
 for (int i = 0; i < N; ++i) {
  if (a[row][i] <= 0) continue;
 
// проверяем след станция уже была
  int j;
  for (ij = 0; j < num; ++j)  
   if (i == path[j]) break;
  if (j < num) continue;
 
// делаем шаг
  path[num++] = i;
  len += a[row][i];
 
// нашли путь, проверяем и запоминаем если лучший (сделаете сами)
  if (i == lastStation) {
   ..
  } 
  else 
   Step(path, num, len);  // рекурс
  
// возвращаем шаг
  --num;
  len -= a[row[[i]; 
 }
}
0
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
04.02.2013, 16:44  [ТС]
-1 2 -1 3 - не очень понимаю, почему -1 задана станция?
0
1968 / 824 / 115
Регистрация: 01.10.2012
Сообщений: 4,870
Записей в блоге: 2
04.02.2013, 17:04
Цитата Сообщение от Влад000 Посмотреть сообщение
-1 2 -1 3 - не очень понимаю, почему -1 задана станция?
Значит трамваи не ходют из первой в первую и из первой в третью
0
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
04.02.2013, 19:20  [ТС]
// нашли путь, проверяем и запоминаем если лучший (сделаете сами)
то есть создаем одномерный массив, в который будут записываться -1 2 -1 3 и прочие станции?
0
1968 / 824 / 115
Регистрация: 01.10.2012
Сообщений: 4,870
Записей в блоге: 2
04.02.2013, 19:35
Цитата Сообщение от Влад000 Посмотреть сообщение
// нашли путь, проверяем и запоминаем если лучший (сделаете сами)
то есть создаем одномерный массив, в который будут записываться -1 2 -1 3 и прочие станции?
Нет, просто индексы станций,
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
i
int bestPath[N];
int numBest = 0;
int bestLen = -1;
const int firstStation = 2;  // исходная станция (индекс)
const int lastStation = 5;  // конечная  (индекс)
 
nt main( void )
{
 int path[N];
 path[0] = firstStatin;
 Step(path, 1, 0);
 return; 
}
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
1968 / 824 / 115
Регистрация: 01.10.2012
Сообщений: 4,870
Записей в блоге: 2
06.02.2013, 16:28
Цитата Сообщение от Влад000 Посмотреть сообщение
int j;
и почему такие числа приравниваются? не могу понять.
Если есть "станции", Вы так или иначе храните их в виде массива (в общем случае контейнера). Как Вы зададите станцию с которой начинаете? Индексом (порядковым номером) в массиве. Как Вы напечатаете найденный маршрут? Массивом индексов, напр {2, 0, 1, 5}

Влад, что-то совсем мрачно - видать гульки на уме а не программирование Больше на вопросы типа "ничего не понимаю" отвечать не буду
0
0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64
06.02.2013, 18:15  [ТС]
Спасибо. Просто я задачу саму понять не мог в плане того, как должен выглядеть конечный ответ.

Добавлено через 1 минуту
В общем вот:
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
STEP(*path (пройденный путь), num (число пройденных станций),
len (пройденное время))
{
 row = path[num-1];
  for (i = 0; i < N; i++)
{
 if (a[row][i]<= 0) continue;
// проверяем след станция уже была
  j;
  for (ij = 0; j<num; ++j)
  if (i == path[j]) break;
  if (j < num) continue;
// делаем шаг
path[num++] = i;
len += a[row][i];
// нашли путь, проверяем и запоминаем, если лучший
  if (i == lastStation) {
   int bestPath[N];
int numBest = 0;
int bestLen = -1;
const int firstStation = 2;  // исходная станция (индекс)
const int lastStation = 5;  // конечная  (индекс)
 
nt main( void )
{
 int path[N];
 path[0] = firstStatin;
 Step(path, 1, 0);
 return; 
}
  } 
  else 
   Step(path, num, len);  // рекурс
  
// возвращаем шаг
  --num;
  len -= a[row[[i]; 
 }
}
все так?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.02.2013, 18:15
Помогаю со студенческими работами здесь

Использование хранимой процедуры с возвратом состояния
Добрый день. Не могу понять как считывать состояние процедуры. ALTER PROCEDURE . @login nchar(20), @pass nchar(15) AS BEGIN if...

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

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

Найти точку минимума функции методом случайного поиска с возвратом и наилучшей пробы
Здравствуйте. помогите решить задачку. надо найти точку минимума функции методом случайного поиска с возвратом и наилучшей пробы. функция...

Заданное множество (1,2,3,4). Вывести все перестановки заданного множества методом поиска с возвратом
Заданное множество: A {1,2,3,4}. Вывести все перестановки заданного множества с помощью метода поиска с возвратом.


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Камера 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 и по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru