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

Формула программиста
основатель — Волосатов Евгений Витольдович
Вступай в Телеграм чат проекта

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

  • На этом уроке мы напишем алгоритм поиска вширь.
    Однако, запустить его не удастся. Почему?
    Это вам самостоятельное задание, разобраться
    в причине, и найти способ, как это исправить.
  • Дата отправки отчёта: 29 апреля 2016 г.
  • Задание выполнено: за 1 час. 00 мин.
  • Чему научился: Понял особенности перебора коллекции с помощью цикла foreach
  • Что было сложным: Исправить ошибку)
  • Комментарии: Как я понял при переборе елементов колеекции с помощью цикла foreach можно только считывать эти самые элементы но не изменять их в процессе. Поэтому в 2 методах пришлось создавать дополнительные коллекции, в которых содержаться информацию о вершинах графа и перебирать уже их. Скорее всего есть более эфективный способ решения. Посмотрим в следующих уроках :)
  • Оценка видео-уроку:
Отчёт от 4538 за Коллекция графов / Широкий алгоритм


Отчёт от 4538 за Коллекция графов / Широкий алгоритм




Оцени работу

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

24. Олюшка
Олюшка
ответить
→  Платон  # Коллекция графов / Широкий алгоритм / 2016-04-29 21:42

Платон, очень хорошие знания получил в этом уроке! Рада что все у тебя так хорошо получается!


1. Евгений Волосатов
Евгений Волосатов
ответить
→  Платон  # Коллекция графов / Широкий алгоритм / 2016-04-29 08:36

Молодец, Платно. Всё правильно, разобрался.



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




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

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

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

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


Научился: Алгоритму поиска в ширину
Трудности: Разобраться в коде и найти свою ошибку
Без комментариев-без комментариев


Научился: Написал функцию поиска в ширь. Проблема возникает как я понял потому, что во время прохода по колекции ее значения изменяются и это выдает исключения. Как вариант исправления можно вместо Hashtable использовать Dictionary и тогда в цикле foreach добавить преобразование .ToArray(). После этого программа работает. Для того чтобы исправить ситуацию с Hashtable я нашел выход в том, что все индексы можно перевести в массив методом CopyTo(array, from). Так как в методе GetAllVertex нас интересуют только индексы всех вершин, то как бы не изменялись цвета, обновлять полученный массив не будет нужды. В итоге было дописано следующее: Array arr = new int[vertexes.Keys.Count]; vertexes.Keys.CopyTo(arr, 0); foreach (int number in arr) { yield return number; }
Трудности: Не очень было понятно как лучше исправить ситуацию с Hashtable