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

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

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

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




Оцени работу

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

5649. Максим Лапшинов
Максим Лапшинов
ответить
→  Новопашин Владимир  # Коллекция графов / Широкий алгоритм / 2016-09-23 19:45

а ты клонируй колекцию и ошибка проподет


  • Отчёт оценивали:
    24Олюшка+1   459Сергей Сергеевич+1   10670Сергей Соколов+1   1Евгений Волосатов+1   1713Виталий0   11017Владимир Петреченко+1   4699Сергей Витальевич+1   9789Александр+1   3506Алексей|BrisK|Кривицкий+1   2146Иван+1   4467Alcatraz+1   6452Кирилл Шмойлов+1   10673Алексей Хонин+1   7303Игорь+1   5649Максим Лапшинов+1   1710Степан+1   8959Максим Саратов+1   6203Николай (nick27m)+1   7276Ильшат+1   7238Константин+1   10553Дмитрий0   10558Иван Воронин+1  

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




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

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

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

Ты в любой момент сможешь отписаться от рассылки.
Научился: Понял особенности перебора коллекции с помощью цикла foreach
Трудности: Исправить ошибку)
Как я понял при переборе елементов колеекции с помощью цикла foreach можно только считывать эти самые элементы но не изменять их в процессе. Поэтому в 2 методах пришлось создавать дополнительные коллекции, в которых содержаться информацию о вершинах графа и перебирать уже их. Скорее всего есть более эфективный способ решения. Посмотрим в следующих уроках :)
Научился: Реализации алгоритма поиска вширь на уровне кода, поиску причин возникновения Exception-a "Collection was modified; enumeration operation may not execute".
Трудности: Особых сложностей не было . Понадобилось время для пошаговой проверки алгоритма.
Урок понравился тем, что пришлось разбираться в причинах возникшей ошибки. Выяснил, что при исп-ии foreach (int nr in ВсеВершины()) в методе УстановитьЦвет(Цвет цвет), Hashtable вершины вернул при 1м проходе номер 12й вершины, т.е. эл-ты расположились в обратном порядке (по убыванию). Заменив строку foreach (int nr in ВсеВершины()) на for (int nr = 0; nr < вершины.Count; nr++) алгоритм последовательно прошёл все вершины (от 0 до 12й) и уже без exception-a. Второй момент, в классе ПоискВШирь исправил строку граф.УстановитьЦвет(Граф.Цвет.чёрный) на граф.УстановитьЦвет(a, Граф.Цвет.чёрный) - иначе все вершины графа будут окрашиваться чёрным при извлечении 1го эл-та из очереди. Если не прав - жду ваших замечаний .