Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/21: Рейтинг темы: голосов - 21, средняя оценка - 4.86
2 / 2 / 0
Регистрация: 19.11.2019
Сообщений: 193

Реализовать алгоритм BFS

05.05.2020, 18:24. Показов 4509. Ответов 1
Метки bfs, c# (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите реализовать поиск в ширину по графах
уже сделал DFS и DLS, а BFS уже не могу
вот это DFS
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
32
33
34
35
36
37
38
39
40
41
42
    class DepthFirstSearch
    {
        private HashSet<Node> visited;
        private LinkedList<Node> path_DFS;
        private Node goal;
        public LinkedList<Node> DFS(Node start, Node goal)
        {
            visited = new HashSet<Node>();
            path_DFS = new LinkedList<Node>();
            this.goal = goal;
            DFS(start);
            if (path_DFS.Count > 0)
            {
                path_DFS.AddFirst(start);
            }
            return path_DFS;
        }
 
        private bool DFS(Node node)
        {
            node.Handler();
            if (node == goal)
            {
                return true;
            }
            visited.Add(node);
            foreach (var child in node.Children.Where(x => !visited.Contains(x)))
            {
                if (DFS(child))
                {
                    path_DFS.AddFirst(child);
                    return true;
                }
            }
            return false;
        }
 
        internal object DFS(Node n06, Node n10, int v)
        {
            throw new NotImplementedException();
        }
    }
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
32
33
34
35
36
37
38
39
40
41
        private static void PrintPath_BFS(LinkedList<Node> path_BFS)
        {
            Console.WriteLine();
            if (path_BFS.Count == 0)
            {
                Console.WriteLine("You shall not pass!");
            }
            else
            {
                Console.WriteLine(string.Join(" -> ", path_BFS.Select(x => x.Name)));
            }
            Console.Read();
        }
    }
 
    class Node
    {
        public string Name { get; }
        public List<Node> Children { get; }
 
        public Node(string name)
        {
            Name = name;
            Children = new List<Node>();
        }
 
        public Node AddChildren(Node node, bool bidirect = true)
        {
            Children.Add(node);
            if (bidirect)
            {
                node.Children.Add(this);
            }
            return this;
        }
 
        public void Handler()
        {
            Console.WriteLine($"visited {this.Name}");
        }
    }
Вложения
Тип файла: rar ALG0-lab06-07.rar (283.7 Кб, 20 просмотров)
1
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.05.2020, 18:24
Ответы с готовыми решениями:

Алгоритм BFS // поиск в ширину
Написать программу, которая с помощью алгоритма BFS(поиск в ширину): выполняет поиск в приведенном выше графике, сохраненном с...

BFS на 1С
Кто-нибудь писал на 1С обход графа в ширину? Поделитесь кодом...

Функция bfs
Приветствую всех!!, У меня никак не получается одна задачка связанная с функцией bfs((. Напишите код пожалуйста... Вот и сама задачка: ...

1
2 / 2 / 0
Регистрация: 19.11.2019
Сообщений: 193
05.05.2020, 19:33  [ТС]
Уже сам сделал
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace ALG0_lab06_07
{
    class BreadthFirstSearch
    {
        private HashSet<Node> visited;
        private LinkedList<Node> path_BFS;
        private Node goal;
 
        public LinkedList<Node> BFS(Node start, Node goal)
        {
            visited = new HashSet<Node>();
            path_BFS = new LinkedList<Node>();
            this.goal = goal;
            BFS(start);
            if (path_BFS.Count > 0)
            {
                path_BFS.AddLast(start);
            }
            return path_BFS;
        }
 
        private bool BFS(Node node)
        {
            node.Handler();
            if (node == goal)
            {
                return true;
            }
            visited.Add(node);
            foreach (var child in node.Children.Where(x => !visited.Contains(x)))
            {
                if (BFS(child))
                {
                    path_BFS.AddLast(child);
                    return true;
                }
            }
            return false;
        }
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.05.2020, 19:33
Помогаю со студенческими работами здесь

Bfs без очереди
Реализация функции dfs без стека выглядит так void dfs (int i, int j){ maze=0; if (i &gt; 0 &amp;&amp; maze == 1) dfs(i-1,j); if (i...

BFS и DFS в графах
Не могу понять почему при обходе графа в ширину (void bfs или void bfs1) выдает пустые результаты Вершин графа 5, ребер 4, координаты...

BFS и удаление вершины графа
Дан граф, который необходимо представить списком смежности или матрицей смежности. Требуется запустить bfs(поиск в ширину) из заданной...

BFS для ориентированного графа
Имеется граф такого вида. Что непонятно: 1)Как добавлять смежные вершины в очередь для их проверки? 2)Как вообще организовать этот...

Нужен пример алгоритма BFS
Здравствуйте. Помогите мне запрограммировать на Паскаль алгоритм BFS или дайте ссылку на программу. Сам алгоритм я знаю осталось лишь...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru