Задача из Собеседования в Microsoft (Бинарные Деревья)

Поділитися
Вставка
  • Опубліковано 21 гру 2024

КОМЕНТАРІ • 591

  • @sashalukin
    @sashalukin  7 місяців тому +2

    Создал Telegram канал, в котором рассказываю о жизни в Лондоне, работе в Google и подготовке к собеседованиям. Подписывайтесь: t.me/saschalukin

  • @alexanderpoplooukhin7448
    @alexanderpoplooukhin7448 Рік тому +222

    Объяснение - просто 🔥. Это тот случай, когда у автора есть реальная способность доходчиво и лаконично объяснить алгоритмы и структуры данных

    • @victorprohorov6201
      @victorprohorov6201 Рік тому +3

      а я не особо понял. лучше было бы если бы автор показал как это работает на примере

    • @yaroslavandreyev4246
      @yaroslavandreyev4246 Рік тому +2

      @@victorprohorov6201 а чем этот пример, был не примером?

    • @victorprohorov6201
      @victorprohorov6201 Рік тому +1

      @@yaroslavandreyev4246 я не понял как мы переходим по вершинам.

    • @КонстантинКолибаба
      @КонстантинКолибаба Рік тому +1

      @@victorprohorov6201 рекурсивно, начиная с корня, до всех листов. Стрелки только немного сбивают - реально граф неориентированный, раз путь может идти от левого поддерева через вершину в правое поддерево.

  • @sozinovss
    @sozinovss Рік тому +22

    Александр, Спасибо! . У тебя талант объяснять сложные вещи, не останавливайся! Не оторваться - очень понятно и легко усваивается. Затягивает - утром вместо того, чтобы кофе налить - пошел смотреть другие ролики.

  • @lufavetskaya
    @lufavetskaya Рік тому +56

    После обнаружения таких замечательных пояснений, начинаешь очаровываться алгоритмами! Спасибо за вашу работу. Нереально приятно изучать тему, с таким обучающим контентом❤

  • @ddflruc
    @ddflruc Рік тому +4

    Я считаю, что это один из лучших каналов на ютубе по подготовке к алгоритмической секции!
    Спасибо огромное!!!

  • @lostislandable
    @lostislandable Рік тому +239

    POV устраиваешься в среднестатистический проект: просят на собеседовании решить задачу на алгоритмы и математические знания а после офера отправляют таски по верстке 🤯

    • @nickoni4
      @nickoni4 Рік тому +5

      Ну так радоваться надо) изи мани)))

    • @HyperTextTransferProtocol-l6m
      @HyperTextTransferProtocol-l6m Рік тому

      Да, но это не плохо

    • @bass1387
      @bass1387 Рік тому

      Задачи могут быть разные, зависит от потребностей бизнеса))

    • @DevBer
      @DevBer Рік тому +2

      Лишь бы платили как за алгиритмические задачи с вышматом под капотом =))

    • @lostislandable
      @lostislandable Рік тому +1

      @@DevBer было б так, не было б пределу счастья :)

  • @smileborsh9780
    @smileborsh9780 Рік тому +3

    Даже ударение в слове «красивее» стоит правильно. 👏🏻💐

  • @larnikodis1501
    @larnikodis1501 Рік тому +5

    Саня, классный парень без понтов и умный. Так держать! Еще и спортивный.

  • @Nardan78
    @Nardan78 Рік тому +4

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

  • @tima-obzor
    @tima-obzor Рік тому +4

    Перешёл по рекам ютюба, подготовился, чаёк заварил. Накануне изучал видео о парадоксах математики и нобелевских лауреатах, доказавших ту или иную теорему. Так сказать был готов к удивляться, и что в итоге??? Теперь я понимаю из за каих специалистов у меня винда лагает)

  • @seyapanda108
    @seyapanda108 Рік тому +8

    Спасибо за видео. В случае с деревьями желательно еще уметь решать dfs, bfs итерационно, а не только с помощью рекурсии. Если дерево будет выражено в список, то рекурсия уже не очень хороший вариант решения. Ну и не редко на собесах просят решить итерационно после решения с рекурсией

  • @vitali5615
    @vitali5615 9 місяців тому

    Oh man, it's totally awesome! I checked out a ton of videos, and this one is pure magic. Everything is crystal clear! Thanks a million, bro!

  • @ИльяСтубарев
    @ИльяСтубарев Рік тому +16

    Очень круто, спасибо. Давно хотел разобраться с деревьями

  • @ILikeActions
    @ILikeActions Рік тому +14

    Отличный разбор и отличная подача! Ждем следующей задачи)

  • @АлексейСамарский-б7ц

    шикарно, спасибо за разбор, с первой легко было, а вторая заставила подольше посидеть)

  • @vasiliypupkin6311
    @vasiliypupkin6311 Рік тому +8

    Дружище, спасибо тебе большое, пока твой разбор лучшее, что я видел в Ютубе для начинающих, разборы очень качественные, может сделаешь чек лист для джунов, что учить и как, спасибо!

  • @ValkRover
    @ValkRover Рік тому +1

    Послушал с удовольствием. :)
    Удачи!

  • @badcloud
    @badcloud Рік тому

    Ого, поначалу зафтыкал, думал че за сложное объяснение, а на деле несколько строк кода емае. Мужик! Спасибо!

  • @qumi645
    @qumi645 Рік тому +3

    Шикарная подача!
    Всё доступно и понятно, особенно с учетом того, что я далек от программирования:)

  • @НикитаКривицкий-щ5ы

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

    • @НикитаКривицкий-щ5ы
      @НикитаКривицкий-щ5ы Рік тому +1

      @@ilya9261 задачи по дп слишком разные. книги раскрывают или совсем базовые задачи, которые не попадутся на собеседовании, или книги написаны исключительно для олимпиадников. потому что как раз из олимпиад эти задачи и вышли. я решил 60(возможно не показатель) задач по дп на литкоде. с барского плеча 10 максимум повторились. но в основном это довольно уникальные задачи, которые чаще всего решаются как по учебнику(рекурсия с мемоизацией, bottom up и может оптимизированное решение) но дойти к рекуррентому соотношению, я считаю, вообще не просто. ну или все вокруг меня слишком умные и им проще решать)

    • @ilya9261
      @ilya9261 Рік тому

      @@НикитаКривицкий-щ5ы а стоп, ну раз ты нарешал 60 задач по дп без подглядываний, то с чего бы ты тупил то на подобных задачах как в видео? она решается проще простого. Либо не интуитивно понимаешь свои же решения, либо хз в чем проблема. 60 не показатель, но уже что-то, не 0 (у меня сейчас меньше и я трудоустроен), продолжай в том же духе)

    • @НикитаКривицкий-щ5ы
      @НикитаКривицкий-щ5ы Рік тому

      @@ilya9261 я перечитал свой коммент и понял, что забыл написать, что я так и не научился решать дп задачи)

    • @ilya9261
      @ilya9261 Рік тому

      @@НикитаКривицкий-щ5ы дак ты же 60 штук решил. Как решал?

    • @Saby1983x
      @Saby1983x Рік тому +3

      @@НикитаКривицкий-щ5ы
      > но дойти к рекуррентому соотношению, я считаю, вообще не просто. ну или все вокруг меня слишком умные и им проще решать)
      Это фигня и в жизни редко пригождается, поэтому примеры довольно вымученные.
      Я программирую 22 года, 10 в качестве хобби и 12 профессионально. Подобные задачи пригодились 3 раза - 2 в качестве хобби (игровой проект) и 1 на работе - тоже игровой, совершенно не типичный проект.
      Мой совет - требуют leetcode? пожелайте счастливого пути и ищите руководителя, который понимает, какие задачи Вы будете писать на работе. Если Вы не пишете AI для игр, то с подобными задачи будете иметь дело раз в пятилетку. Сядете, спокойно продумаете алгоритм (да, вместо 20 минут возможно целый день потратите) - но я Вас уверяю, отлаживать алгоритм и писать подходящие структуры для быстрой его работы (чтобы оно занимало вменяемое время и при этом можно было сохранить вне 1 Гигабайта) - Вы будете писать гораздо дольше.

  • @georgiirozhnev
    @georgiirozhnev Рік тому +2

    Блестящий разбор! Ждём продолжения

  • @42jU29Mp
    @42jU29Mp Рік тому +1

    Про Space: O(n) для первой задачи не сразу догадался. Видео хорошее.

  • @enitefall
    @enitefall Рік тому +2

    даже я понял после такого понятного объяснения! Супер!

  • @saimonshaplygin7867
    @saimonshaplygin7867 Рік тому +5

    Привет! Саш, спасибо за разборы. У тебя очень хорошо получается. Рассказываешь сложные вещи доступным языком.
    Во второй задачке ошибка при инициализации поля answer. Изначально оно должно быть минус бесконечность. Так как если подать на вход функции дерево с одной вершиной, значение которой равно отрицательному числу. В версии на видео в качестве ответа мы получим 0, а не отрицательное число
    ps. Может быть кто-то уже писал об ошибке, но я не нашел в комментах

    • @alexyevdokimov642
      @alexyevdokimov642 Рік тому

      И не только инициализация, там вообще с нулем нельзя сравнивать. Надо с минимально отрицательным. С чего автор решил, что понятие максимум это только для положительных чисел. А если там во всех узлах отрицательные value? Уже не будет правильного ответа? Ну а по сути, логика в целом верная. А рекурсия - это все равно зло :)

    • @Game_Pro_
      @Game_Pro_ 11 місяців тому

      а кем работаешь? просто интересн окакая зарплата@@alexyevdokimov642

  • @NickRossik
    @NickRossik Рік тому +1

    В книге грохаем алгоритмы я не очень понял бинарные деревья, но зато теперь как понял! 😁
    Супер объяснение, спасибо.

  • @VanillaCorpse
    @VanillaCorpse 4 місяці тому

    хоспади как комфортно и понятно, подписалась)

  • @Hello-g5b3p
    @Hello-g5b3p Рік тому +18

    Вторая задача - все же answer = Integer.MIN_VALUE; Так как в случае с деревом состоящим всего из одного отрицательного желемента - ответ будет 0, а должен быть - само это отрицательное число.

    • @slavakonashkov
      @slavakonashkov Рік тому

      Правильное замечание, но этого не достаточно. В коде, там где max, тоже нужно логику поменять.

    • @Hello-g5b3p
      @Hello-g5b3p Рік тому +1

      @@slavakonashkov нет, в остальном все правильно.

    • @tsv83
      @tsv83 Рік тому +9

      Просто решение у автора некорректное. Либо задача поставлена криво. Автор декларирует "дальше не пойдём" но по факту это работает только если отрицательный узел один и сравнивается с мнимым узлом, чьё значение 0. Если у 5 будет не один ребёнок -2, а ещё один, скажем -5 - решение будет несоответствовать задаче.

    • @МихаилПершин-х3и
      @МихаилПершин-х3и Рік тому

      @@tsv83 работать будет и с вашим примером, поскольку с нулём сравнивается и helper(node.left) и helper(node.right), который, в свою очередь содержит максимальную сумму дальнейшего пути, то есть, в момент сравнивания уже учитывается, есть ли там что-то дальше, как то с "-3", у которой ребёнок "5"

    • @tsv83
      @tsv83 Рік тому

      @@МихаилПершин-х3и нет, не будет

  • @imishka
    @imishka Рік тому +23

    Есть у меня смутное предположение что если все значения в дереве будут отрицательными, то maxpathsum выдаст 0, а не мах отрицательный ответ, для этого наверное answer должен быть равен по умолчанию значению самой верхней вершины.

    • @gheoblink8862
      @gheoblink8862 Рік тому +2

      Нет, по условию, мы имеем право взять 0 вершин, так что наш минимум - 0

    • @NoName-hi8bv
      @NoName-hi8bv Рік тому

      Тож так думаю. Что если стоит отрицательное значение, а ниже много положительных

    • @Богдан-з5з7п
      @Богдан-з5з7п Рік тому

      0 означает, что мы не берем левого\правого ребенка. Но после этого ответ для нашей вершины становится max(left, right) + val. Так что ошибки нет, и ответ может быть отрицательным, если положительных вершин вовсе нет

    • @imishka
      @imishka Рік тому +4

      ​@@Богдан-з5з7пэто возвращает функция helper, параллельно она записывает в переменную класса answer (максимум среди answer=0 и тем что вернул helper на данном шаге)
      А далее цель maxpathsum просто вывести эту переменную, соответственно если все отрицательно то answer так и останется 0.
      Выше написали что это вроде как правильно если ничего не брать, но в таких случаях наверное лучше уточнять данный кейс.

    • @michaeldeoz
      @michaeldeoz Рік тому +1

      @@gheoblink8862 разве условие задачи не найти максимальный путь? Если два значения отрицательны не значит что одно из них не может быть максимальным?

  • @ЗахарТерех
    @ЗахарТерех Рік тому

    Лучший! Приятно смотреть) Продолжай записывать видео и не забрасывай)

  • @2difficult2do
    @2difficult2do Рік тому +2

    Хорошая подача и подробное объяснение. Буду заглядывать 😊

  • @golodnenkiy
    @golodnenkiy 9 місяців тому

    Классные задачи, спасибо автору.
    P. s. Не описать ту радость, когда сначала пытаешься решить задачу, а потом смотришь ролик, где твоё решение совпадает с решением автора.
    p.p.s Только сделать Answer и проверять на max в helper-e, я не догодался, а просто запихивал возможные пути в лист, а потом из него макс брал.

  • @oleksandrl4136
    @oleksandrl4136 Рік тому

    Дуже корисний канал. Дякую за Вашу роботу.

  • @Максим-у6у2ф
    @Максим-у6у2ф Рік тому +5

    Продолжай, брат )
    У меня ничего не получается на литкоде ))
    Хотя принцип обхода знаю, но сложно уложить стэк в голове ))

    • @КириллЧе-я5ы
      @КириллЧе-я5ы Рік тому +1

      Стек на самом деле самая простая структура после массива… можно представить себе тарелку с блинами - ты ж с низу блин не вытащишь и вниз не положишь🥴

    • @Максим-у6у2ф
      @Максим-у6у2ф Рік тому +1

      @@КириллЧе-я5ы да, так-то все понятно ))
      просто когда данные в стеке и тебе надо о них помнить это другое нежели тарелки представить )) это тарелки с данными ))

  • @lyubov_zhulina
    @lyubov_zhulina Рік тому

    Если хотите понять деревья, посмотрите это видео 👌 идеально, большое спасибо за столь подробное объяснение 🔥🔥🔥

  • @ОлегКарташев-т4л

    Очень понравился формат. Сразу оформил подписку. Делай больше таких разборов, и добавляй их в отдельный плейлист на канале =)

  • @niyazkhannanov5790
    @niyazkhannanov5790 7 місяців тому

    Спасибо! посмотрел несколько роликов - очень доходчиво

  • @mtigames188
    @mtigames188 Рік тому

    Круто! Спс! С первого раза непонятно, пересмотрю на досуге еще несколько раз)

  • @eugenefedoryachenko8793
    @eugenefedoryachenko8793 Рік тому

    Я смотрел твои видео чуть больше года назад, получил оффер с релокацией в европу)
    Теперь смотрю твои видео перед собеседованием в яндекс, но в этот раз решил подписаться)

    • @Gr-wv9rb
      @Gr-wv9rb Рік тому

      В Европе не сложилось?

    • @eugenefedoryachenko8793
      @eugenefedoryachenko8793 Рік тому

      @@Gr-wv9rb сложилось, просто яндекс предлагает больше денег, при этом ехать не далеко

    • @melheor4909
      @melheor4909 Рік тому

      Я после его видосов получил офферы на альфа центавру, а второй на Ксандар. Вот думаю куда лететь

    • @eugenefedoryachenko8793
      @eugenefedoryachenko8793 Рік тому

      @@melheor4909 я если что не писал, что я только после его видосов получил оффер, я в процессе подготовки натыкался на его видео, и объяснения мне понравились, даже е смотря на то, что тогда я собесился на позицию мидла в ts, а теперь на позицию синьора в go)

    • @melheor4909
      @melheor4909 Рік тому

      @@eugenefedoryachenko8793 да я понял))

  • @polinakir2991
    @polinakir2991 Рік тому +2

    Супер! Красавчик!

  • @ОлексійСобран
    @ОлексійСобран Рік тому

    Ха-ха. Сегодня защищал лабораторную в универе, плохо сдал, а вот сейчас захожу в ютуб, чтобы найти, под какой видосик покушать, и вижу это! 🤩🤩🤩
    Леди Фортуна, интернет и ютуб, спасибо вам! 😅

  • @go8tt
    @go8tt Рік тому +1

    ты классный парень, спасибо за такие ролики С:

  • @FenBender01
    @FenBender01 Рік тому +2

    Отличный разбор. Буду давать эту задачу на собеседованиях :)

  • @AnderPython-tw3kp
    @AnderPython-tw3kp Рік тому +1

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

  • @UnrealSPh
    @UnrealSPh Рік тому +3

    Спасибо за видео.
    Единственное, хотелось бы уточнить во второй задаче. Наверное в требования входило условие, что результат должен быть положительным.
    В противном случае мы не покрыл кейс когда все ноды содержат отрицательные значения. Наибольший среди отрицательных тоже можно найти

    • @Jimoshi1
      @Jimoshi1 Рік тому

      Я конечно может чего не понимаю, но разве отрицательные значения не меньше положительных ПО УМОЛЧАНИЮ. Если все вершины отр. то максимальное будет самое меньшее отрицательное.

    • @the__Wizard
      @the__Wizard Рік тому

      @@Jimoshi1 в этом то и прикол, что такое решение не рассмотрено

  • @tsaykostya
    @tsaykostya Рік тому

    Классный канал, автор приятный парень и никакого высокомерия

  • @RockyTheDog756
    @RockyTheDog756 Рік тому +1

    Одна из лучших подач материала!

  • @HarryKastuchsky
    @HarryKastuchsky Рік тому +12

    Каждый раз, когда собираюсь менять компанию, готовлюсь к таким задачам как в первый раз, затем на несколько лет забываю, и далее по кругу. Может быть лет 20 назад эти ОСНОВЫ ИЗ ЧЕГО ВСЕ СТРОИТСЯ и нужны были кому-то, сейчас для большиства разработки это вообще мимо. Впервые я изучил это все для собеседования, наверное, после 2х лет работы программистом, и никакого всевидящего ока в мир разработки мне не открылось, прошел собес и забыл, как всегда. С тем пор я поменял 4 компании и 3 страны, и заметил что зачастую на собесах попадаются консерваторы, которые считают, раз им это интересно, и раз они это заботанили, все вокруг должны это знать, и не важно что для проекта это нафиг не нужно, как будто это какие-то невероятные знания, смешно) Знание архитектурного дизайна намного важнее как по мне, потому что ты приходишь в компанию, и твой онбординг сокращается в разы, потому что ты уже скорее всего понимаешь как работает система. А эти стуктуры, достаточно знать что это такое, что такое бывает, и какая структура для чего работает, и для этого не обязательно решать какие-то сложные задачи и разбираться в них до транзиторов. Первая задача еще адекватная, но вторая это по-моему уже перебор, я бы наверное и решать ее не стал, потому что мне это тупо не интересно)

    • @MrOldschoolrocknroll
      @MrOldschoolrocknroll Рік тому +3

      Если занимаешься простейшим формашлёпством или CRUDошлёпством, где нет ни хайлоада ни интересных задач, то да, это не пригодится. Но как только захочешь отойти от чужих либ и написать своё (более подходящее и масштабируемое решение), то упрёшься в узкость своих знаний, да даже тупо не зная как работает структура данных не сможешь оценить и быть уверенным, что нагруженное место не взорвётся в рантайме.

    • @HarryKastuchsky
      @HarryKastuchsky Рік тому +3

      @@MrOldschoolrocknroll оо подъехали спецы нефармашлепы!
      1) Я написал "А эти стуктуры, достаточно знать что это такое, что такое бывает, и какая структура для чего работает, и для этого не обязательно решать какие-то сложные задачи и разбираться в них до транзиторов. ", с чего ты взял что я "даже тупо не знаю как работает структура данных" и призываю вообще на них забить?
      2) Я написал это в контексте собеседований, что зачастую их спрашивают когда они на проекте вообще не нужны. Если ты курнул и решил "написать своё (более подходящее и масштабируемое решение)", то флаг тебе в руки, никто не скажет тебе что структуры и алгоритмы для них не нужны.
      3) И если ты "не зная как работает структура данных не сможешь оценить и быть уверенным, что нагруженное место не взорвётся в рантайме", то у меня для тебя плохие новости.

    • @MrOldschoolrocknroll
      @MrOldschoolrocknroll Рік тому +3

      ​@@HarryKastuchsky Как же у тебя бомбануло то господи. Я же не конкретно про тебя писал а об индустрии в целом. Но раз ты воспринял всё на свой счёт, то у тебя с этим похоже какие-то проблемы))

    • @alexjuly7097
      @alexjuly7097 4 місяці тому

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

  • @zebrasbtl
    @zebrasbtl Рік тому +1

    Просто супер, все просто и понятно!

  • @РусланПолянский-х7б

    Спасибо за понятное объяснение.

  • @sergiigordiienko2494
    @sergiigordiienko2494 Рік тому

    Приятно смотреть и слушать. Очень понятное и детальное объяснение. Большое спасибо!

  • @saveekglushchenko6903
    @saveekglushchenko6903 Рік тому

    Думаю, что Вы хороший человек. Спасибо за видео

  • @goodvin8554
    @goodvin8554 Рік тому +1

    Спасибо за разбор. Хотелось бы почаще.

  • @BellaLugoshi
    @BellaLugoshi Рік тому +1

    напоминает обучение в автошколе - я купил тонюсенькую книжку с ПДД и учу правила, а остальные накупили разборы билетов и усиленно штудируют их.
    Но да - я потом сел и поехал на своем Заз-968М, а девочки расселись по новым Кайенам. Так что может вы и правы XD

  • @dimasw99
    @dimasw99 7 місяців тому

    От души братишка, под пиво вечерком посмотреть самое оно!

  • @МихайлоДвалі
    @МихайлоДвалі Рік тому +2

    Лучший ❤ 😊

  • @Lammax2012
    @Lammax2012 Рік тому

    Отличное объяснение! Just keep going! )

  • @warface_cheaters_caught
    @warface_cheaters_caught Рік тому

    Когда ты сказал, что нужно "найти путь", а потом продолжил говорить именно про сумму ветки, меня это смутило. Изначально из твоих слов верно было подумать, что требуется найти путь, то есть последовательность нод, список, так скажем, состоящих в ветке с наибольшей суммой. Как говорится, без внятного тз результат будет "хз" :)

    • @sovahc
      @sovahc Рік тому +1

      Путь - это список нод (ну или список направлений). Так что задача не решена, автор собеседование не прошел :)

  • @РустамНуриев-ю9т

    Разбор задачи хорошо подан. Классный контент. Буду ждать еще разборы алгоритмов

  • @oOJIEWAOo
    @oOJIEWAOo Рік тому

    Ура! Ты вернулся! Спасибо тебе за разбор

  • @hopelesssuprem1867
    @hopelesssuprem1867 Рік тому +2

    Спасибо за классные видео. Продолжай выпускать задачки по faang

  • @ChannelYoJo
    @ChannelYoJo Рік тому +1

    Динамическое программирование на деревьях! Крутизна!

  • @reHgoc
    @reHgoc Рік тому

    спасибо за разбор. Помню как на собеседовании на Unity dev решал задачу через алгоритм Дэйкстры (вглубь и вширь), а оказывается есть более простой способ.

  • @danilabagatyriya5737
    @danilabagatyriya5737 Рік тому

    Когда сидел и не понимал, как решать, а потом сразу понял🙏🏾
    Just do it!

  • @Sh.Vladislav
    @Sh.Vladislav Рік тому

    Круто! Прям все по полочкам, реально класс! Спасибо👍🙏

  • @P0dCasts.io6o
    @P0dCasts.io6o Рік тому

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

  • @Poli.Pavlovich
    @Poli.Pavlovich Місяць тому

    Супер объяснение!

  • @АнатолийГлазков-ъ8и

    Хорош, отличное объяснение !

  • @xlv4553
    @xlv4553 Рік тому

    Топ, спасибо большое за такое объяснение, жду новых задач!

  • @TheYozka
    @TheYozka Рік тому +1

    Хорошая подача материала

  • @_alexanderd
    @_alexanderd Рік тому +2

    Спасибо за разбор задачи!

  • @halcyon-s
    @halcyon-s Рік тому +1

    Большое спасибо за урок!

  • @dreambreaker226
    @dreambreaker226 Рік тому

    Да . столько раз ты это объяснял в элементарном введении в К.М. а они всё равно не понимают и спорят. Пасибо за ролик

  • @GrigoriySokolik
    @GrigoriySokolik Рік тому

    Спасибо за интересный ролик. Удивительно, что решение с рекурсией "проходит".

  • @yaroslavandreyev4246
    @yaroslavandreyev4246 Рік тому +1

    Очень хорошо объясняете👍

  • @Boobnovslava
    @Boobnovslava Рік тому +1

    Спасибо за разбор, деревья моя ахилесова пята

  • @Mexanikkmm
    @Mexanikkmm Рік тому +1

    Спасибо, довольно понятно и очень полезно.

  • @iqfunru
    @iqfunru 8 місяців тому +2

    7:17 Пустого дерева не бывает по определению: дерево это граф, а граф имеет хотя бы одну вершину.

  • @natsurukasumi3370
    @natsurukasumi3370 Рік тому +2

    Гарний опис та рішення! Тільки я не зрозуміла останню задачу і тепер є думки на ніч 😅
    Дякую за розбір, дуже класно

    • @sashalukin
      @sashalukin  Рік тому +2

      Радий що сподобалось!

  • @Алексей-х5ж9п
    @Алексей-х5ж9п Рік тому +4

    Как раз вчера в университете начали проходить эти деревья)

  • @loam
    @loam 6 місяців тому

    Я как-то раз был на собеседовании Майкрософт)
    Тётенька такая вредная попалась. Села прямо передо мной и уставилась в мой лист что я пишу. Я тогда мало умел справляться с такими ситуациями, от напряжения все забыл 😂
    Просто попрощался и ушел 😂
    А когда только вышел из здания, решение мне в голову пришло 😂

  • @cinemaSage_1
    @cinemaSage_1 Рік тому +1

    Great. Thank you for the explanation. Now trees seems not so terrible...

  • @acthanger7420
    @acthanger7420 Рік тому

    Классный урок, очень доходчиво, пасибо))

  • @denvir2254
    @denvir2254 Рік тому

    Ооооочень подробно объясняешь))
    Прям для младших классов как будто бы

  • @-Critical_Thinking-
    @-Critical_Thinking- Рік тому

    0:40 если для кого-то это звучит сложно, то о каком собеседовании в Гугл может идти речь?

  • @artemmarkaryan1125
    @artemmarkaryan1125 Рік тому +1

    17:28 разве у вершины 20 вычисленное значение не должно быть 30? Это ведь сумма max(0, левой дочки), max(0, правой дочки), и собственного значения

  • @meerable
    @meerable Рік тому +2

    Слово лист прозвучало, но без определения)
    Ну и казалось бы очевидный факт «почему дерево», ведь графически мы рисуем скорее густые корни?)
    Ну просто наши деревья растут вниз)

  • @iforvard
    @iforvard Рік тому

    Максимально понятно все стало, спасибо!

  • @VasillaRobocraft
    @VasillaRobocraft Рік тому

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

  • @bass1387
    @bass1387 Рік тому

    Это гениально!!))

  • @martis-dev
    @martis-dev Рік тому +3

    Спасибо, просто и понятно.
    Только я не понял одно, почему во второй задаче мы не идем ниже по дереву если у ноды оба отрицательных ребенка? А если за одним из них стоит +40? Или это имелось в виду уже результат суммы всех детей ниже?

    • @egorrichmining1069
      @egorrichmining1069 Рік тому

      результат суммы предварительно считали всем (макс из нижележащих)

  • @AlexZvukov
    @AlexZvukov Рік тому +2

    Отлично, спасибо. PS: качество подтянул 👍

    • @sashalukin
      @sashalukin  Рік тому +1

      Спасибо, учусь :)

  • @MVOralov
    @MVOralov Рік тому

    В T-SQL такие штуки, как практические алгоритмы решения прикладных задач прохождения по Parent-Child иерархиям - реализуется при помощи рекурсивных CTE. Используется, например, для обработки и поддержания товарных справочников в ритейле. Ну а сама суть так же ложится в основу b-tree индексов, которые стараются на уровне их ядра поддерживать баланс «веса» значений детей

  • @РашитГареев-ю8я
    @РашитГареев-ю8я 7 місяців тому

    Спасибо за полезное видео

  • @leomysky
    @leomysky Рік тому

    Спасибо за видео
    Не очень понял идею с второй задачей, но суть уловил

  • @alexjuly7097
    @alexjuly7097 4 місяці тому

    17:22 это верно только для дерева без нод, если у нас есть хотя бы одна нода (-10) мы не можем её отбросить.

  • @overskam2699
    @overskam2699 Рік тому +1

    побольше бы таких видео

  • @kusam7384
    @kusam7384 Рік тому

    13:38 почему не имеет смысла включать две вершины с отрицательными значениями?
    Ведь одно уменьшит ответ меньше, чем другое

  • @awer1986
    @awer1986 Рік тому +3

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

    • @Saiii1024
      @Saiii1024 Рік тому

      можно заменить ноль в решении на min value для типа

  • @erwerwer2761
    @erwerwer2761 Рік тому +1

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

    • @deutschuntergrad
      @deutschuntergrad Рік тому

      В Microsoft как обычно девайсы предполагают чисто теоретическими и рассуждают примерно так: если пользователю для процесса не будет хватать оперативной памяти, то память несложно нарастить. Позвоните в службу поддержки Microoft, и мы проконсультируем вас по данному вопросу.

  • @kseniiaefremova4696
    @kseniiaefremova4696 9 місяців тому

    Чудесная подача теории! И код на джаве действительно понятен, хоть я и по питону больше!
    У меня вопрос по первой задаче: почему при вычислении space comlexity худший вариан - это дерево, которое идет только на лево или только на право?