Курсы по программированию

Формула программиста
основатель — Волосатов Евгений Витольдович
Вступай в Телеграм чат проекта | Обход блокировки
Игровой комплекс Сокобан - Введи код скидки

Коллекция графов / Широкий алгоритм

  • На этом уроке мы напишем алгоритм поиска вширь.
    Однако, запустить его не удастся. Почему?
    Это вам самостоятельное задание, разобраться
    в причине, и найти способ, как это исправить.
  • Дата отправки отчёта: 7 мая 2016 г.
  • Задание выполнено: за 40 мин.
  • Чему научился: Научился реализации алгоритма поиска вширь в коде.
  • Что было сложным: Разобраться с изменением коллекции при ее переборе.
  • Комментарии: На сколько я понял, изменение коллекции при переборе не рекомендуется, в этом случае рекомендуют формировать новую коллекцию.
    Я примерно так и сделал, заодно и реализовал интерфейс ICloneable в нашем классе графа.
    Немного кривенько пока вышло, но, посмотрим, что предлагает нам следующий видеоурок.
  • Оценка видео-уроку:
Отчёт от 9263 за Коллекция графов / Широкий алгоритм




Оцени работу

 
Сохранить страницу:


Начинаем практику по языку C#




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.


Научился: Перебирать коллекцию во время её изменения
Я запустил пошагово и убедился, что мы изменяем коллекцию (о чём и говорилось в ошибке). Так что я просто заменил foreach на for (нам же никто не говорил, что вершины нужно возвращать в каком-то определённом порядке), таким образом перебор выполняется по индексу элемента коллекции и ошибка не возникает =)


Научился: реализации поиска в ширину на графе
Трудности: исправил ошибку, но решение некрасивое: скопировал ключи коллекции в массив