Форум программистов, компьютерный форум, киберфорум
Turbo Pascal
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
4 / 4 / 0
Регистрация: 21.10.2010
Сообщений: 20

Найти самый длинный простой путь в графе.

06.11.2010, 09:47. Показов 4068. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Найти самый длинный простой путь в графе.


Вот подобная задача которая находит вершины графа, недостижимые от заданной вершины.
Pascal
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
40
41
42
43
44
45
46
47
48
49
50
51
Program NonReachability;  
     Uses  Crt; 
    Type Uk=^Rebro; {тип – указатель на ребро}
        Rebro=Record    {тип, описывающий ребро графа}
     Ver1, Ver2 : Integer;      {вершины ребра}
     Next: Uk;              {указатель на следующее ребро}
     Bool: Boolean;     {признак прохождения по ребру}
        end;
Var  P, P1:Uk;   
     N, M, i, j, a : Word;
     Way : Set of Byte; {множество достижимых вершин }
{–––––––––––––––––––––––}
Procedure Input;
  Begin     
    Write(' Введите количество вершин :  ');  ReadLn(N);
    Write(' Введите количество ребер :  ');      ReadLn(M);
    P:=nil;   {цепочка ребер пуста}
    For i:= 1 to M do
       begin New(P1); {создание нового ребра}
        Write('Введите 1-ю вершину ', i, ' -го ребра:  ');  Read(P1^.Ver1);
        Write('Введите 2-ю вершину ', i, ' -го ребра:  ');  Read(P1^.Ver2);
        P1^.Bool :=TRUE;  P1^.Next :=P; {прикрепляем новое ребро к началу}
        P:=P1;   {новое ребро становится началом цепочки}
         end;
End; {of Input}
{––––––––––––––––––––––}
Procedure Poisk (i:Byte);
    Var tt:Uk;      {указатель на текущее ребро}
Begin
 Way:=Way+[i];  {добавляем вершину во множество достижимых}
 tt:=p;         {перемещаем указатель на начало цепочки}
 While tt<>nil do {пока не конец цепочки}
  begin If (i=tt^.Ver1) and tt^.Bool    {находим ребро, которое выходит}
    then    {из i-ой вершины,в которой мы не были}
    begin tt^.Bool := FALSE; {отмечаем, что прошли}
     Poisk(tt^.Ver2);    {уходим на вторую вершину}
     tt^.Bool := TRUE;  {снимаем отметку  о посещении }
    end;
    tt:=tt^.Next;
  end;
End; {of Poisk}
BEGIN  ClrScr;
    Input; {ввод графа}
Write('Задайте вершину, для которой ищутся недостижимые вершины: '); ReadLn(A);
    Way:=[];    {обнуляем множество достижимых вершин}
    Poisk(A);   {процедура обхода графа}
    For j:=1 to N do
      If not (j in Way) then WriteLn( j, '-я вершина недостижима из вершины ',  A);
    If Way = [1 .. N] then WriteLn('Все вершины достижимы из вершины ', A);
    ReadLn
END.
Добавлено через 11 часов 22 минуты
т.е орграфа
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.11.2010, 09:47
Ответы с готовыми решениями:

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

Алгоритм, обратный алгоритму Дейкстры (найти самый длинный путь)
может кто помочь разобраться в коде,и сделать так что бы программа искала не самый короткий путь,а самый длинный?

Найти самый длинный путь от корня дерева к листьям и вернуть сумму его элементов
Дано бинарное дерево, содержащее целые числа. Найти самый длинный путь от корня дерева к листьям и вернуть сумму его элементов

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.11.2010, 09:47
Помогаю со студенческими работами здесь

Найти длиннейший простой путь в графе
Нужна помощь идеей, как это реализовать. Может быть есть какое то классическое решение? Код написать, думаю, смогу сама Найти в графе...

Нужно найти максимальный простой путь в графе
Здравствуйте Есть такая задача: &quot;Нужно найти максимальный простой путь в графе&quot; Как я понял, тут нужно использовать какой-либо...

Найти самый короткий путь из первой вершины в последнюю по счету в заданном графе методом динамического программирования
Всем добрый день! У меня вопрос - найти кротчайший путь из первой вершины в последнюю по счету в заданном графе методом динамического...

В двумерном массиве найти самый длинный и самый короткий элемент
В двумерном массиве найти самый длинный и самый короткий элемент

В двумерном массиве найти самый длинный и самый короткий элемент
В двумерном массиве найти самый длинный и самый короткий элемент


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
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 и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru