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

Формула программиста
основатель — Волосатов Евгений Витольдович
Вебинар «Мир! Труд! Май! Для программиста.» начнётся через 14 час. 58 мин.

Комбинаторика / Рекурсия. Заливка области

  • Пишем алгоритм заливки, как в программе Паинт.
  • Дата отправки отчёта: 21 апреля 2016 г.
  • Задание выполнено: за 1 час. 10 мин.
  • Чему научился: Создавать алгоритм заливки.
  • Что было сложным: Самомму написать программу, без просмотра видео.
  • Комментарии: Я бы не смог написать программу такую сам! Мне очень сильно понравился урок! Даже моим друзьям очень понравилась программа! Да, Евгений Витольдович прав, на эту программу можно смотреть вечно.
  • Оценка видео-уроку:
Отчёт от 5567 за Комбинаторика / Рекурсия. Заливка области




Оцени работу

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

1. Евгений Волосатов
Евгений Волосатов
ответить
→  Albert  # Комбинаторика / Рекурсия. Заливка области / 2016-04-21 21:04

Не я придумал её, прочитал о ней в журнале Наука и жизнь в 14 лет. Давным давно, но запомнилась.


  • Отчёт оценивали:
    9263Андрей Н.+1   9567Максим+1   9288Pučko Antonina+1   9237Mais+1   3506Алексей|BrisK|Кривицкий+1   8380zhikharevav+1   6925Артём+1   4805Сергей В+1   1Евгений Волосатов+1   4992Николай+1   4467Alcatraz+1   689Igorenzia+1   6452Кирилл Шмойлов+1   5567Albert+1   1947Denis+1   6644valerys Nikola+1   6282Михаил+1   1537Сергей+1   7119Новопашин Владимир0   791Валерий Жданов+1   9768Ender+1  

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




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

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

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

Ты в любой момент сможешь отписаться от рассылки.
Научился: Стал лучше понимать рекурсию, повторил работу с выводом информации на консоль.
Трудности: Понять алгоритм рекурсивной заливки.
Евгений Витольдович, благодарю за этот прекрасный пример объяснения работы рекурсии, все наглядно и понятно. Однако первоначально не все было очевидно. Логически-то понятно, например, сначала закрашиваем вверх, потом вниз, потом влево, потом вправо и если дошли до тупика (то есть, условие выхода из рекурсии - закрашенная клетка), то тогда рисуем звездочку и выходим из функции. И технически было понятно, что тут используется своего рода механизм "раскрутки" стека и поэтому мы всегда знаем куда вернемся, главное, чтобы было определено условие выхода из рекурсии. Были проблемы другого рода: понять, как все это вместе работает, особенно когда вложенность вызовов становится большой :) Поэтому решил пошагово проверить работу алгоритма, вместо Thread.Sleep() написал Console.ReadKey() и медленно, но верно смотрел что выдает программа при каждом вызове функции. Здесь еще хорошо подошло то, что показывается направление следующего хода, очень наглядно. В итоге, доволен результатом, спасибо :)
Научился: Создавать рекурсивную функцию
Трудности: Осознавать, что стоит за каждым действием, а не пытаться поспеть за видео
Увлекательное зрелище!