Алгоритм Дейкстры

Поделиться
HTML-код
  • Опубликовано: 22 янв 2025

Комментарии • 148

  • @Денис-р5в4з
    @Денис-р5в4з 2 года назад +19

    Большое спасибо. Это лучшее объяснение данного алгоритма, из тех что я встретил на просторах. Понятно и наглядно👍👍

  • @senya5668
    @senya5668 5 лет назад +27

    Пасибо , что спасаете ленивых студентов..

  • @annavasileva5688
    @annavasileva5688 2 года назад +3

    Объяснение с прямой линией вижу в первый раз, и это очень удобно. Спасибо большое!

  • @osenyaaPechen
    @osenyaaPechen 11 лет назад +32

    Вы сэкономили мне кучу времени. Спасибо!

  • @yehorpanchenko10
    @yehorpanchenko10 8 лет назад +2

    Посмотрел куча других видео - ничего не понял. Посмотрел ваше - все понял с самого начала. Спасибо за доступное объяснение.

  • @iluhanse745
    @iluhanse745 Год назад

    Спасибо Вам огромное! Наконец-то окончательно разобрался с этим алгоритмом.

  • @RomanOleynik92
    @RomanOleynik92 8 лет назад +1

    Благодарю вас за информационный, легко усвоиемый видео урок.

  • @КристинаМищенко-з1м

    Огромное спасибо! Вы помогли мне понять этот алгоритм!

  • @leonidsah
    @leonidsah 4 года назад +2

    Вы просто лучший

  • @Sushigirl1809
    @Sushigirl1809 5 лет назад +3

    Благодаря вам , получил 90 баллов по дискретной математике. Спасибо!!!

  • @НиколайХодарев-ь8н
    @НиколайХодарев-ь8н 3 года назад

    Спасибо огромное, уже столько времени прошло, а акутально и по сей день:)

  • @s4ygak
    @s4ygak 3 года назад

    Пересмотрел несколько раз, поставил лайк, алгоритм запомнил, идеально

  • @Faustism
    @Faustism 10 лет назад +7

    Отлично! Очень доходчиво. Спасибо!

  • @andrushabt
    @andrushabt 3 года назад

    спасибобольшое вам за очень простое обьяснение. здоровья и процветания вам

  • @lif0CLUB
    @lif0CLUB 8 лет назад +1

    Большое спасибо,вам за ваши труды

  • @vrakitine
    @vrakitine 7 месяцев назад +2

    В институте я много слышал про конечные автоматы (КА), но это всё было теорией - как облака в небе: воды в них много, а напиться нельзя. Корпел три месяца после института, пока не реализовал свой КА в коде в 1981 году. Сейчас существует методология программирования на этой основе - v-agent oriented programming (VAOP) - и множество примеров её реализации. Лучше начать знакомство с VAOP с этой статьи на Medium: "Bagels and Muffins of Programming or How Easy It Is to Convert a Bagel into a Black Hole" или на Хабре: "Бублики и Коржики Программирования".

  • @Enthe0genic
    @Enthe0genic 7 лет назад +2

    Спасибо большое! Очень доходчиво объясняете.

  • @MySaluto
    @MySaluto 12 лет назад +3

    Хочу заметить, что алгоритм физически напоминает поведение воды когда она накапливается на неровном ландшафте, первым делом заливает пустоты, затем если вокруг высокие препятствия - ищет следующий кратчайший путь повышая уровень воды. Повышение уровня воды - это аналог "удорожания маршрута".

  • @КатяБабчинская-ю5ш

    Спасибо за урок..Всё ясно и понятно!!)нет ничего лишнего - всё по теме!!

  • @АртёмЧацкий-э9в
    @АртёмЧацкий-э9в 10 лет назад +1

    Большое спасибо за доступное объяснение

  • @ДимаРекун-ю8т
    @ДимаРекун-ю8т 9 лет назад

    благодаря видео я сдела свою контрольную работу по графам))) спасибо БОЛЬШОЕ

    • @Kirsanov2011
      @Kirsanov2011  9 лет назад

      +Дима Рекун Ради этого я и трудился...

  • @dailyInfo24
    @dailyInfo24 Год назад +1

    спасибо, тятя, вы очинь умнний. Я сам узбек делал поступило ни унивирсэтет. очинь сложна(((. вы памоч спосибо

  • @Мурчащиекотятки
    @Мурчащиекотятки 8 лет назад +1

    Спасибо, всех благ вам за ваши труды :)

  • @archwarden7004
    @archwarden7004 5 лет назад +1

    Очень интересно и доходчиво, спасибо!

  • @fogrinn7525
    @fogrinn7525 4 года назад

    Спасибо большое вам за обьяснение!

  • @MsTurugor
    @MsTurugor 12 лет назад +1

    Благодарю) Долго не мог понять, теперь разобрался)

  • @ya_gema
    @ya_gema 6 лет назад

    Спасибо Вам большое, очень доступно и понятно объяснили.

  • @arthuralunts5424
    @arthuralunts5424 2 года назад

    Спасибо, док.

  • @haruhiismygoddess2727
    @haruhiismygoddess2727 12 лет назад +1

    Никак не мог разобраться, как работает протокол динамической маршрутизации OSPF, он как раз основан на методе Дейкстры. Посмотрел видео, разобрался. Спасибо)

  • @Kirsanov2011
    @Kirsanov2011  11 лет назад +3

    Для поиска последовательности узлов алгоритм надо еще немного доработать. Но не принципиально, просто на каждом этапе запоминать, из чего складывается минимальная сумма, а потом стирать ее, если найдется еще меньше (а в ней тоже уже хранится последовательность...). На любом алгоритм.языке это не трудно сделать. Я это делал в Maple (см. мою книгу "Графы в Maple", она есть в сети)

  • @HHBiber
    @HHBiber 6 лет назад

    Отличное представление!

  • @ellviira
    @ellviira 9 лет назад

    Большое спасибо,все понятно и доступно

  • @Kirsanov2011
    @Kirsanov2011  12 лет назад +15

    просмотрите еще раз и почитайте книги... Успехов!

  • @micebirds
    @micebirds 5 лет назад

    Спасибо большое, всё очень понятно!

  • @ЮлияКравцова-о6ф
    @ЮлияКравцова-о6ф 6 лет назад

    Отличное объяснение) Спасибо!!

  • @IvanGavr
    @IvanGavr Год назад +1

    Спасибо. А если так?! Найти все пути из первой точки в последнюю; затем для каждого найденного пути найти расстояние; сохранить все в массиве, отсортировать массив расстояний по возрастанию, то первое значение и будет кратчайшим путём. Это уже будет далеко от алгоритма Дейкстры?!

    • @Kirsanov2011
      @Kirsanov2011  Год назад +1

      Вот в том то и дело - как найти ВСЕ пути? Перебором? Думайте. Вопрос не закрыт. Алг Дейкстры - это одно из решений

    • @IvanGavr
      @IvanGavr Год назад

      @@Kirsanov2011вот такой у меня получился способ, (без кода) на основе упорядоченной матрицы: ruclips.net/video/FBk5vDdusoY/видео.html

  • @KartDev
    @KartDev 5 месяцев назад

    Пока что самое понятное объяснение, которое я встречал в инете

  • @Pancelet
    @Pancelet 4 года назад

    Мэи с заставкой в начале звучит грандиозно

  • @Guveba
    @Guveba 12 лет назад +2

    Хорошо, нашли мы кратчайшее расстояние, а как узнать через какие точки? Из полученной таблицы я наглядно этого не увидел.

  • @JeckPot111
    @JeckPot111 8 лет назад

    Мужик, спасиб большое

  • @kattyrein9900
    @kattyrein9900 9 лет назад +6

    Отличное видео, все очень понятно! Единственный вопрос, как вычислять сам путь (порядок вершин), а не только длину пути?

    • @Kirsanov2011
      @Kirsanov2011  9 лет назад +1

      +Katty Rein Пишите каждый раз список предшествующих вершин

  • @Gidrionix
    @Gidrionix 10 лет назад

    Спасибо огромное!!!!!!!!!!!!!!

  • @batista12001
    @batista12001 11 лет назад +2

    Назначь длиной каждого ребра единицу, тогда этот алгоритм выведет тебе наименьшее кол-во рёбер от начальной до конечной вершины, а это и есть маршрут.

  • @СергейБренько-ы3л
    @СергейБренько-ы3л 10 лет назад

    Спасибо автору

  • @SahkaP
    @SahkaP 12 лет назад +1

    С этой таблицей я запутался еще сильнее

  • @АртёмТютюнник-ы7р
    @АртёмТютюнник-ы7р 11 лет назад +4

    Отлично! Разобрался с алгоритмом Дейсктры!
    Нет ли у Вас такого же доступного урока по алгоритмам Форда и Флойда? Не могу разобраться.
    Заранее благодарен!!!

  • @vladimirduchenchuk8518
    @vladimirduchenchuk8518 12 лет назад

    Огромное спасибо! Ни как не мог найти ошибку в своей реализации алгоритма=)

  • @blk8722
    @blk8722 11 лет назад

    Всё отлично понятно, спасибо за видео)

  • @rusg777
    @rusg777 12 лет назад

    Спасибо большое!

  • @Kirsanov2011
    @Kirsanov2011  11 лет назад +2

    Ничего не изменится, хоть 1000000! Можете еще алгоритмом Флойда воспользоваться, это еще проще, а потом свериться с Дейкстрой, все совпадет. Все эти алгоритмы доказываются, это только я так по-простому все рассказал... См. книги.

  • @gudapavella1751
    @gudapavella1751 4 года назад +3

    Теперь я понимаю, почему в универе частенько ничего не понимал, этож надо, на 75% видео сказать, я ошибся в самом начале, давайте я за 2 секунды все переделаю.

  • @ustesrendel
    @ustesrendel 2 месяца назад

    А для чего добавлять значение предыдущей метки?

  • @mcd-ti2wv
    @mcd-ti2wv 4 года назад

    Самое понятное разъяснение

  • @flukalpes
    @flukalpes 8 лет назад +11

    А как найти сам путь, а не только его длину?

    • @hskdjs
      @hskdjs 8 лет назад +7

      Как вариант - при обновлении метки сохранять информацию о вершине-предшественнике.

  • @antontelyaev4927
    @antontelyaev4927 8 лет назад +1

    супер!

  • @Andrea13339
    @Andrea13339 11 лет назад

    Надо внимательнее, видио-гид очень подробно расписан: шаг за шагом. Спасибо за алгоритм!

  • @treugolinik
    @treugolinik 11 лет назад +1

    Спасибо!!!

  • @GAVVVR
    @GAVVVR 11 лет назад

    Спасибо большое, все понятно)

  • @AntonioNeStradivary
    @AntonioNeStradivary 11 лет назад

    В рамках моей задачи, для поиска маршрута я могу использовать следующий подход - удалять из графа все длинные пути к одной и той-же вершине, оставляя только короткие. При вычислении веса вершины, если новый вес больше текущего, это значит, что найден дополнительный и более длинный путь к этой вершине. Следовательно этот путь (ребро) я могу удалить из графа. Для моей задачи это не критично. Таким образом в конце получаю граф в котором все точки связаны только одним маршрутом. Думаю это сработает.

  • @Suuuuuuhovich
    @Suuuuuuhovich 11 лет назад +2

    Могли бы вы рассказать о методе Беллмана-Мура? Для отрицательных весов

  • @Kirsanov2011
    @Kirsanov2011  11 лет назад +12

    См, например, мою книгу "Графы в Maple"

  • @Kirsanov2011
    @Kirsanov2011  11 лет назад +3

    Будет и Форд-Флойд. А Форд-Фалкерсон уже есть. Ищите.

  • @trampller
    @trampller 11 лет назад

    Спасибо.

  • @FixedA
    @FixedA 9 лет назад

    не могли бы пожалуйста, про D* еще рассказать

  • @Kirsanov2011
    @Kirsanov2011  11 лет назад

    Зачем блок-схема? Могу и саму программу на простом и понятном языке Maple. См. стр. 111 моей книги "Графы в Maple" (книга есть в сети, но уже нет в продаже). Но там задействованы и спец.команды Maple, хотя их назначение довольно ясно...

  • @ЮлияЛапина-ц4л
    @ЮлияЛапина-ц4л 4 года назад

    спасибо огромное, у меня завтра экзамен по теории алгоритмов, надеюсь сдам)

  • @ablgmv
    @ablgmv 8 лет назад

    спасибо!

  • @БабкаБомБом
    @БабкаБомБом 8 лет назад

    Спасибо)

  • @sobolmx
    @sobolmx 11 лет назад

    superb! spassibo!

  • @kyzmitch2
    @kyzmitch2 2 года назад

    у нас в универе никогда не говорили "снести"

  • @AntonioNeStradivary
    @AntonioNeStradivary 11 лет назад

    Я извиняюсь, просто посмотрел описание на Вики, и уж очень странным оно мне показалось. Под впечатлением, отправил сообщение не по адресу. Прошу извинить.
    Я только одного момента не понял, алгоритм Дейкстры находит именно ВЕЛИЧИНУ пути, в вашем примере, это 5, либо он может найти сам путь, т.е. перечень всех узлов по порядку которые нужно посетить?

  • @ЛюссанаБазарова
    @ЛюссанаБазарова 4 года назад

    Здравствуйте,этот алгоритм с первого раза приведет к кратчайшему пути?
    Просто я для интереса выбрала не самый короткий путь на некоторых шагах а в итоге прошла более коротким путем чем если бы я действовала по алгоритму

    • @Kirsanov2011
      @Kirsanov2011  4 года назад

      Не может этого быть! Ошиблись.

    • @ЛюссанаБазарова
      @ЛюссанаБазарова 4 года назад

      @@Kirsanov2011 да,ошибка была в сносе,а где обзор на алгоритм Форда-Беллмана?

  • @BbeeTV
    @BbeeTV 11 лет назад

    просто мне именно блок-схема нужна для курсовой работы
    все объяснение ваше понял, а вот как нарисовать блок-схему не понимаю(

  • @ПетрАвен-к7ч
    @ПетрАвен-к7ч 9 лет назад

    спасибо

  • @dudejustdude
    @dudejustdude 12 лет назад

    Сделал лабу четверти группы, спасибо)

  • @SahkaP
    @SahkaP 12 лет назад

    Спасибо, но я просто пытался вспомнить алгоритм.
    Википедия расставила все на своим места

  • @jmnext1338
    @jmnext1338 7 лет назад

    Здравствуйте. А алгоритм флойда уошера у вас нет? Я ваши видео глянул но ничего такого не встретил. Заранее спасибо

  • @dm.vortex4171
    @dm.vortex4171 9 лет назад +3

    я не понял как он с вершины 3 в вершину 2 попал ?

    • @МишаОвчинников-ц8й
      @МишаОвчинников-ц8й 9 лет назад

      +Дмитрий Вихарев , снес "2" с предыдущей строки так как она весит (мы её не прошли), и сравнил - минимальное в получившейся строчке

  • @BbeeTV
    @BbeeTV 11 лет назад

    Могли бы вы нарисовать блок схему к вашему решению и к алгоритму в целом??
    Очень нужно!
    Заранее спасибо!

  • @dizogdizog2591
    @dizogdizog2591 8 лет назад

    Спасибо за ролик в любом случае. но мне кажется надо это понимать на языке символов и алгоритмов. так для общего частного понимания средних к коим и себя отношу умов

    • @MaximumDo
      @MaximumDo 5 лет назад

      имеем 2 массива: дист[n] = [0]*n, tested[n] = [false]*n
      и матрица смежности am[n][n], где, если вершины не связаны, стоит inf
      пока минимальная длина < inf
      tested[minvert] = true
      для всех вершин графа
      если dist[minvert] + am[minvert][i] < dist[i]
      обновляем dist[i]
      ищем вершину с наименьшим дист[i] и tested[i] == false
      minvert = i
      mindist = dist[i]

  • @Денис-з7ч
    @Денис-з7ч 5 лет назад

    Вопрос такой. Если в одном ряду получилось два одинаковых числа и они оба наименьшие, то что делать?

    • @Kirsanov2011
      @Kirsanov2011  5 лет назад +1

      Решение бывает не единственным. Поэтому берите любую. Потом для интереса возьмите другую.

  • @AngelVlad100
    @AngelVlad100 10 лет назад

    А что делать если в ряду 2 одинаковые вершины?Решать относительно каждой?

    • @Kirsanov2011
      @Kirsanov2011  10 лет назад

      Выбирать любую из них.

  • @lerby5512
    @lerby5512 10 лет назад +2

    Безусловно плюс за ваш труд, но, как мне кажется, не помешало бы сделать метку на видео когда начинается сам алгоритм :)

  • @gitarnoob
    @gitarnoob 11 лет назад

    Ясно, алгоритм находит кратчайшее расстояние от одной вершины к остальным, а как быть если мне надо узнать не численное расстояние до остальных вершин, а маршрут (то есть список вершин чтобы в сумме удовлетворяли расстоянию) ?

    • @bond94g
      @bond94g 6 лет назад

      Жалко, лектор этого не рассказал. Там нужно завести ещё один столбец, в котором указывать номер вершины, получившей постоянную пометку на данном шаге. С помощью этого столбца легко восстанавливается кратчайший путь до любой вершины. Также можно построить т.н. дерево кратчайших путей.

  • @AntonioNeStradivary
    @AntonioNeStradivary 11 лет назад

    ок, буду дорабатывать. Спасибо.

  • @Маринаиванова-ф9ь
    @Маринаиванова-ф9ь 9 лет назад

    Находим минимальный путь, а если нужен максимальный путь выбираем на каждом шаге максимум? Спасибо

    • @Kirsanov2011
      @Kirsanov2011  9 лет назад

      +Марина иванова Минимум функции f(x) совпадает с максимумом A-f(x) - просто перевернуть график

    • @Ilichi
      @Ilichi 8 лет назад

      Можете подробней описать, как найти максимальний путь?

    • @Kirsanov2011
      @Kirsanov2011  8 лет назад +2

      1. Берете какое-нибудь большое число А, большее, чем вес любой дуги графа.
      2. Все веса f_k графа заменяете на A-f_k
      3. В полученном графе находите минимальный путь. Для исходного графа он будет максимальным.

    • @Ilichi
      @Ilichi 8 лет назад

      Благодарю за ответ!

  • @traxternberg
    @traxternberg 6 лет назад

    Представленный алгоритм неполный, путь по вершинам, образующим минимальное расстояние не фиксируется. И вообще, объяснение не Дейкстры, родной алгоритм предусматривает обход по всем соседним вершинам, на которых еще не был. Далее Обход соседей от соседних вершин и т.д. ...

  • @ВалентинТятьков
    @ВалентинТятьков 10 лет назад

    Спасибо, все понятно. Но у нам в университете используют алгоритм из 6-ти ходов... То еще занятие, но результат тот же значит?

  • @Suuuuuuhovich
    @Suuuuuuhovich 11 лет назад

    Как найти максимальный путь

    • @aivashyna
      @aivashyna 10 лет назад

      выбирай найбольшее значение в каждой строке.

  • @alexandristomin2410
    @alexandristomin2410 8 лет назад

    Спасибо за видео, всё понятно, но у меня вопрос, что делать если в конце 2 повторяется постоянная вершина 4 ?

    • @Kirsanov2011
      @Kirsanov2011  8 лет назад +1

      Не совсем ясен вопрос. Постоянная вершина только один раз появляется. Потом ход на нее запрещен.

    • @alexandristomin2410
      @alexandristomin2410 8 лет назад

      у меня повторяется наименьшее число

    • @Kirsanov2011
      @Kirsanov2011  8 лет назад +1

      Если два одинаковых наименьших числа - берите любое.

    • @alexandristomin2410
      @alexandristomin2410 8 лет назад

      Kirsanov2011 ясно, спасибо вам

    • @fenrrisulfr
      @fenrrisulfr Год назад

      @@Kirsanov2011 а что делать, если я пришла к определенной вершине (до конечной еще не дошла), но из нее ходы только в постоянные вершины, т.е. тупик?

  • @john1987742
    @john1987742 4 года назад

    ничего не понял

  • @ekklesiast
    @ekklesiast 8 лет назад

    Не понимаю, в вики описание отличается.

    • @Das.Kleine.Krokodil
      @Das.Kleine.Krokodil 6 лет назад

      в вики графически представлено и псевдокодом
      там тоже хорошая подача материала

  • @АлександрБирич-щ2с
    @АлександрБирич-щ2с 7 лет назад +2

    Ааа зачем алгоритм дейскры если крускала быстрее

    • @Kirsanov2011
      @Kirsanov2011  7 лет назад +1

      Алгоритм построения минимального остова? Зачем? или у Крускала есть еще алгоритм, который я не знаю?

    • @АлександрБирич-щ2с
      @АлександрБирич-щ2с 7 лет назад

      чтобы дойти до вершины 6

    • @АлександрБирич-щ2с
      @АлександрБирич-щ2с 7 лет назад

      и кстати за сколько работает алгоритм дейкстры

    • @АлександрБирич-щ2с
      @АлександрБирич-щ2с 7 лет назад

      за квадрат или линию на логарифм

    • @dmitrypetrov8491
      @dmitrypetrov8491 7 лет назад +5

      1) Алгоритм Крускала используется для построения минимального остова, а не для поиска кратчайших путей в орграфах.
      2) Чтобы говорить об асимптотике алгоритма Дейкстры, нужно определиться со структурами данных, которые Вы собираетесь использовать.
      В самой наивной реализации, если Вы будите хранить граф в виде матрицы смежности, то алгоритм будет работать за O(n^2), где n - число вершин графа. В самом деле, вам нужно будет сделать n шагов, на каждом из которых просматривать n вершин.

  • @ПррроРос
    @ПррроРос 5 лет назад

    Вообще то это и так видно что кратчайшее расстояние 5 данный зачем формализм?

    • @juneority
      @juneority 5 лет назад +3

      а если там тысячи вершин?

  • @BbeeTV
    @BbeeTV 11 лет назад

    Или хотя бы понятный алгоритм написать, по которому можно будет нарисовать блок-схему

  • @Inseidful
    @Inseidful 7 лет назад

    слабо что-то понял, почему 5 если минимальное расстояние 1-3-6?

    • @IvanShulga
      @IvanShulga 7 лет назад

      5 - это минимальное расстояние (минимальная сумма длин ребер), а не номер вершины, т.е длина ребра (1)->(3) = 1; длина ребра (3) -> (6) = 4. итого минимальное расстояние (1)->(3)->(6) = 1+4 = 5

  • @padla6304
    @padla6304 4 месяца назад

    4.5 < 5

  • @vasyapupkin997
    @vasyapupkin997 5 лет назад

    угарный чел

  • @dizogdizog2591
    @dizogdizog2591 8 лет назад

    Спасибо посмотрел
    но вот же )))ru.wikipedia.org/wiki/%D0%90%D0%BB%D0%B3%D0%BE%D1%80%D0%B8%D1%82%D0%BC_%D0%94%D0%B5%D0%B9%D0%BA%D1%81%D1%82%D1%80%D1%8B

    • @Kirsanov2011
      @Kirsanov2011  8 лет назад +1

      Мне эта инф знакома. Скоро будет новый вариант видео "Модификация алг Дейкстры".

  • @mkdotam
    @mkdotam 12 лет назад

    Если владеете английском посмотрите вот сюда, /watch?v=xT5o1QCeWS8 - очень все четко объяснено.