Алгоритмы и Структуры Данных. Урок 5: Жадные алгоритмы. Введение.

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

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

  • @alishevN
    @alishevN  6 лет назад +2

    КУРС ПО GIT: www.udemy.com/course/git-alishev/?referralCode=71994763964B8E2E6A4E

  • @maksimponomarev3610
    @maksimponomarev3610 6 лет назад +72

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

    • @indigolight6007
      @indigolight6007 3 года назад +1

      знаешь что такое монтаж?)))

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

      @@indigolight6007 ну так про это и речь, некоторые авторы даже не вырезают подобное на этапе монтажа.

  • @pertshgalstyan6189
    @pertshgalstyan6189 6 лет назад +42

    Самый крутой чувак который не лениться поделиться со своими знаниями

  • @KishinevSV
    @KishinevSV 6 лет назад +29

    Насчёт необходимости остановки в первом способе на 750км слукавил)) если заправка на 550км и проехать на одной заправке можно 400 и конечная точка 950 то нет необходимости в остановке на 750-м километре. Тогда первый способ получится на столько же эффективен как и первый). А вот если конечную точку сдвинуть немного вперёд, тогда да.
    Спасибо, интересно.

    • @alishevN
      @alishevN  6 лет назад +3

      Да! Вы правы :)

    • @VadimC5917
      @VadimC5917 6 лет назад +5

      А если по пути пришлось выжидать в пробках, плюс и за жары включил кондиционер. Так от точки 550 не доехать до 950.
      Есть самый безопасный вариант: почаще останавливаться. А вдруг одна закрыта на ремонт, нет топлива или программа не работает.
      Большое спасибо Алишев за обучение. Мир и здоровье тебе!

    • @sense3247
      @sense3247 4 года назад +9

      @@VadimC5917 В условии сказано, что 400 км можно проехать на полном баке. Значит уже в эти 400 км включены предполагаемые расходы. Если это не так, то задачу нужно формировать заново. Это уже другое ТЗ.

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

      @@VadimC5917 вам даны четкие условия. Зачем вы придумываете себе всякие другие условия которых даже невозможно реализовать на голом коде

  • @Svoboda2000
    @Svoboda2000 6 лет назад +10

    у этого канала великое будущее!

  • @maximvolvach3783
    @maximvolvach3783 3 года назад +1

    Спасибо большое за ваш труд!

  • @molotok1726
    @molotok1726 4 года назад +10

    надо заметить что задачу с числами эффективнее решать не с помощью выбора-удаления элемента так как очевидно что ассимптотика квадратичная у такого решения, а с помощью обратной сортировки (например быстрой или слиянием) за nlogn

    • @ДмитрийЧебанов-ю1м
      @ДмитрийЧебанов-ю1м 2 года назад

      Эта задача решается за O(n) без сортировки при помощи вспомогательного массива на 10 элементов.

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

      @@ДмитрийЧебанов-ю1м вспомогательный массив это уже доп. память, лучше O(nlogn) зато in-place

    • @ДмитрийЧебанов-ю1м
      @ДмитрийЧебанов-ю1м 2 года назад

      @@molotok1726 ну если лишних 48 байт жалко, тогда да

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

      @@ДмитрийЧебанов-ю1м дело не в том какой объем памяти а в том что далеко не все яп способны выделять память в статике, а значит это лишняя аллокация -> системный вызов под капотом, и как следствие жуткий оверхед по времени. Можно успеть 100500 раз отсортировать массив за O(nlogn) чем ожидать сис.колл

    • @ДмитрийЧебанов-ю1м
      @ДмитрийЧебанов-ю1м 2 года назад

      @@molotok1726 Так мы же про асимптоматику говорим, причем тут лишний сис колл? Если брать те же быструю сортировку и сортировку слиянием, то быстрая не использует дополнительную память, а слиянием постоянно создаёт дополнительные массивы. Тем не менее считается что обе работают в среднем за O(nlogn), а в худшем случае слиянием даже быстрее.

  • @simpleded5454
    @simpleded5454 4 года назад +4

    Молодец, продолжай в том же духе, не глохни! Слушать тебя интересно, у тебя есть на ютубе будущее)))

  • @Сергей-в4ъ4я
    @Сергей-в4ъ4я 6 лет назад +4

    Завтра зачёт, вовремя выложил)

  • @RudiyOrm
    @RudiyOrm 6 лет назад +6

    Спасибо за материал! Еще бы ссылки на презентации - было бы совсем здорово!

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

      Пожалуйста!
      drive.google.com/open?id=1Hx06zrR_e89vYJa7K3VLtSA33I1xqRZ_

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

    Спасибо за урок!

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

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

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

    Просто крутой чел, кстати спасибо за курс по python

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

    Отличный урок. Поставила на паузу, попробовала расписать код сама, а потом послушать тебя. Мой код, конечно, это одноглазый Джо:
    my_list = [3, 1, 7, 9, 9, 5]
    my_list.sort()
    new_list = []
    for i in my_list:
    new_list.append(i)
    new_list.reverse()
    print(new_list)

  • @timur2887
    @timur2887 2 года назад +2

    Но ведь первая задача настолько очевидно проще решается сортировкой в порядке убывания, которую можно было бы осуществить более эффективными алгоритмами, чем предложенное решение O(n^2)

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

      Так автор и использует сортировку выбором. Просто её понять проще, чем quick/mergesort

  • @ДмитрийЧебанов-ю1м
    @ДмитрийЧебанов-ю1м 2 года назад

    С чего это в первой задаче получается глобальный оптимальный результат? Сложность алгоритма будет O(n^2). Можно сделать O(n):
    public class MaxNumber {
    public static void main(String[] args) {
    int[] arr = new int[] {3,1,7,9,9,5};
    int[] temp = new int[10];
    long res = 0;
    for(int i = 0; i=0;i--)
    for (int j = 0; j

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

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

    • @ДмитрийЧебанов-ю1м
      @ДмитрийЧебанов-ю1м 2 года назад

      @@kanaagaat5194 для примера из 6 чисел - да, усложнил. Просто сортировать будет стоить дороже для больших n - O(nlogn). Чем асимптотика этого года отличается от прошлогодней?)

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

    В задаче про монеты. Оно то, конечно, можно разменять по 20 центов, но где взять еще 1 монету номиналом 20 тогда? Или в условии забыли указать, что таких монет (20 центов) две?

  • @ololo2755
    @ololo2755 3 года назад +1

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

  • @МарсельЧаргинов-э3ч

    Можно отсортировать массив по убыванию, и склеить все элементы

  • @Azimbek-iq1kl
    @Azimbek-iq1kl Год назад

    Задача 1
    Lk = [1,3,7,5,9,9)
    Print(sorted(Lk, reverse=Trur))

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

    Ой как часто у меня бывают "ага!" моменты))

  • @Дмитрий-ю9к3г
    @Дмитрий-ю9к3г 5 лет назад +1

    Во второй задаче на одной жадности не уедешь. Если АЗС на 750 километре переместить на 775+1 километр, то произойдет облом)

    • @SplashDmg2011
      @SplashDmg2011 5 лет назад +4

      Зачем что-то перемещать, если есть четкие условия задачи?

    • @Дмитрий-ю9к3г
      @Дмитрий-ю9к3г 5 лет назад

      @@SplashDmg2011 не зачем конечно. Но если переместится, то код придется переписывать.

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

      @@SplashDmg2011по тому что в олимпиадках четкие условия не дают никогда

    • @АлександрМаркелов-ш3ж
      @АлександрМаркелов-ш3ж 4 года назад +1

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

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

    Вопрос автору. Вы показали примеры жадных алгоритмов, а мой вопрос по динамическому программированию, нужно ли использовать динамическое программирование, чтобы найти кратчайший путь из точки A в точку Z с учетом, что путь из A в Z имеет много различных ответвлений и пересечений? В Google Map или в приложении Uber, когда мы задаем начальную точку и конечную точку - приложение нам строит кратчайшую траекторию, используется ли алгоритм динамического программирования там? Означает ли это, что динамическое программирование - это рекурсивный перебор всех возможных вариантов и выбор самого оптимального?

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

      Обычно для нахождения кратчайшего пути используются графы и алгоритм A*

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

    Добрый день) а будет продолжение?

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

    Это же творческий переосмысленный курс San Diego University на Coursera)

  • @MCLoveKherson
    @MCLoveKherson 3 года назад +1

    package day21.AnyTest;
    import java.util.Arrays;
    public class MasSort {
    // Дан неупорядоченный список цифр от 0 до 9. Составить из этих числел наибольшее число
    //in: 317995 out: 997531
    public static void main(String[] args) {
    int[] input = {3, 1, 7, 9, 9, 5};
    int[] output = new int[input.length];
    int max = 0;
    int count = 0;
    int c = 0;
    for (int j=0; j < input.length; j++) {
    for (int i = 0; i < input.length; i++) {
    if (input[i] < 0) {
    continue;
    }
    if (input[i] > max) {
    max = input[i];
    c = i;
    }
    }
    input[c] = -9;
    output[count] = max;
    max = 0;
    count++;
    }
    System.out.println(Arrays.toString(output));
    }
    }

  • @atec1814
    @atec1814 10 месяцев назад

    Если топливо на 400км то 550+400 =950 остановка на 750 не нужна

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

    Решение первой задачи просто рак, у нас сложность выходить O(n^2), причем автор использует фразу "удаляем из массива" и у меня вопрос, как мы это делаем, ибо нулл вместо инта поставить будет не всегда возможно, а удалять ячейку это ооочень дорого. Крч у меня много вопросов, первый задача оптимальной всего решается бакет сортом.