0 / 0 / 0
Регистрация: 05.12.2010
Сообщений: 64

Использование алгоритма поиска с возвратом

26.01.2013, 18:06. Показов 2220. Ответов 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
1974 / 830 / 115
Регистрация: 01.10.2012
Сообщений: 5,019
Записей в блоге: 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
1974 / 830 / 115
Регистрация: 01.10.2012
Сообщений: 5,019
Записей в блоге: 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
1974 / 830 / 115
Регистрация: 01.10.2012
Сообщений: 5,019
Записей в блоге: 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
1974 / 830 / 115
Регистрация: 01.10.2012
Сообщений: 5,019
Записей в блоге: 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru