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

Обход графа (LINQ)

24.12.2018, 23:23. Показов 1155. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет. Подскажите пожалуйста. У меня есть класс Node. Делаю обход графа в ширину.
Вот сам класс
C#
1
2
3
4
5
public class Node
    {
        private List<Node> incidentNode { get; set; }
        public Node Previous { get; set; }
    }
в свойство Previous записывает нод, из которого мы пришли. я сделал экстеншн метод что бы вернуть искомый путь.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 public static class ExtensionNode
    {
        public static List<Node> Puth(this Node node)
        {
            var currentNode = node;
            List<Node> result = new List<Node>();
            while (currentNode != null)
            {
                result.Add(currentNode);
                currentNode = currentNode.Previous;
            }
            return result;
        }
    }
Все просто. Но очень хочется его реализовать с помощью LINQ.
примерно так
C#
1
2
3
4
5
6
7
 public static class ExtensionNode
    {
        public static Func<Node, IEnumerable<Node>> Puth(this Node node)
        {
            return x => // some code
        }
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.12.2018, 23:23
Ответы с готовыми решениями:

Обход графа
Дан неориентированный невзвешенный граф. Для него вам необходимо найти количество вершин, лежащих в одной компоненте связности с данной...

Обход графа
Реализовать обход графа в глубину и в ширину. С клавиатуры задается размер матрицы, а потом вводятся значения. Можно так, чтобы выводил...

Обход графа в глубину
необходимо разбить неориентированный граф на связные компоненты на вход поступает матрица смежности using System; using...

3
 Аватар для Lexeq
1151 / 743 / 483
Регистрация: 21.01.2014
Сообщений: 1,903
24.12.2018, 23:52
privetprivet, боюсь LINQ к вашей ноде не имеет никакого отношения. LINQ имеет дело с перечислениями (IEnumerable).
0
1 / 1 / 0
Регистрация: 03.11.2018
Сообщений: 42
25.12.2018, 00:00  [ТС]
Цитата Сообщение от Lexeq Посмотреть сообщение
боюсь LINQ к вашей ноде не имеет никакого отношения. LINQ имеет дело с перечислениями (IEnumerable).
Хорошо. у меня есть список всех посещенных нодов. оттуда вычленить только нужные ноды получится? начиная с последнего и previous от последнего и так далее? или может просто в функциональном стиле этот метод сделать... так возможно?
0
 Аватар для Lexeq
1151 / 743 / 483
Регистрация: 21.01.2014
Сообщений: 1,903
25.12.2018, 00:06
privetprivet, не понял какие ноды надо вычленитью Для выбора по какому-то признаку используется Where.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.12.2018, 00:06
Помогаю со студенческими работами здесь

Обход графа в глубину
string graph = new string; graph = &quot;a&quot;; graph = &quot;0&quot;; //а graph = &quot;b&quot;;//b graph =...

Обход взвешенного неориентированного графа
Всем привет. Стоит задача обойти и начальной вершины все вершины графа и вернуться в исходную. Граф неориентированный, взвешенный, каждая...

LINQ to XML Как поменять значения, не используя обход?
Всем привет. Пишу небольшой классификатор спама. С помощью LINQ создаю файл с базой слов (см. скриншот). Вопрос 1: как поменять...

Обход графа в ширину - перевести код с C++
Добрый вечер. Умоляю, помогите перевести нижепредставленный код в C#, какой день уже мучаюсь, все не получается, но надо. Буду очень...

Обход графа в ширину с помощью очереди
Объясните пожалуйста реализацию обхода графа в ширину с помощью очереди,читал на этом сайте,но слишком для меня трудно,так как я...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
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 и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru