Тестовое собеседование Java разработчика #24 - Никита Ким

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

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

  • @ibraim3197
    @ibraim3197 Год назад +16

    не бывает сортировки за log(n), лучший алгоритм как раз n*log(n)

    • @EugeneSuleimanov
      @EugeneSuleimanov  Год назад +7

      Да, вы правы - здесь ошибка.
      Сложность по времени - N log N
      Сложность по памяти log N
      Спасибо за уточнение.

    • @LacqueredNoCap
      @LacqueredNoCap Год назад +2

      Уточнение. За O(n*log(n)) отрабатывают сортировки сравнением. Есть такие алгоритмы сортировки подсчетом, как Counting Sort и Radix Sort, которые могу отработать за O(n) при определенных ограничениях на входные данные (диапазон значений, символьная длина значений). Буду рад уточнению на свой комментарий

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

      @@LacqueredNoCap
      Спасибо за комментарий :)
      Если мы говорим про числа, и конечно radix sort будет лучше. В то время, как тот же quickSort - универсальный алгоритм.

    • @МаксМакс-ч8к
      @МаксМакс-ч8к Год назад

      Евгений, спасибо за Ваш труд👍👍👍
      Хотел бы пожелать всем удачи и терпения💪👍👍

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

      @@МаксМакс-ч8к спасибо за отзыв!

  • @МаксимСамойлов-р6ф

    Не успел посмотреть ролик!!!
    Но нет сомнений в качестве!!!
    Просто Евгению с ходу ЛАЙКОС👍👍👍

  • @user-mt2if1ht8n
    @user-mt2if1ht8n Год назад +5

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

  • @Batyrbala
    @Batyrbala Год назад +2

    Каждое видео - на вес золота для начинающих! Спасибо за труды, сенсэй!)

  • @КириллКавалеров-е4з

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

  • @JavaDevOld
    @JavaDevOld Год назад +11

    Евгений, здравствуйте. Готов снять свою шапку, скажу более - свой мозг, перед Вашим терпением...... Парнишка очень волновался, но все-таки думаю, что ему нужно больше решать логических задач на смекалку и упорядочение мышления..... И еще раз убеждаюсь, что не все очевидное является целесообразным. Понимание того, как работает комп необходимо..... Благодарю Вас за Ваше потраченное время. получил удовольствие от Вашего урока...

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

      Спасибо за отзыв!

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

      И операционные системы и модель OSI тоже не помешает

  • @voker8465
    @voker8465 Год назад +2

    Спасибо большое, Евгений, что снова начали делаеть видео и писать статьи на сайте . Очень понравилось про jvm и volatile 😊

  • @ДмитрийБ-е9ъ
    @ДмитрийБ-е9ъ Год назад +3

    Интервью очень понравилось) Никита крут
    Также было видно эмоции/реакции Евгения, в этот момент понимаешь, правильно ли отвечает Никита. Особенно с вопросом про docker, что это виртуальная машина. Ведь у Евгения есть отдельное видео посвящённое Docker'у, где он специально подчеркивал, что Docker - не виртуальная машина =)
    Спасибо за видео, жду новое)

  • @alenache1
    @alenache1 Год назад +8

    огонь 🔥🔥🔥

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

    Спасибо большое за отличные ролики.

  • @axelrod4840
    @axelrod4840 Год назад +6

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

  • @АлександрКостырев-в7ш

    Спасибо за видео :)

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

    Спасибо за видео!Видно было что Никита переживал) особенно на sql.Сразу вспомнил себя на первых собеседованиях.

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

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

  • @ВасильМихальчук-ж7т

    гарне інтерв'ю. Дякую за роботу

  • @MrSashaZykov
    @MrSashaZykov Год назад +4

    На 27:16. Можете пояснить почему мы нарушаем принцип Лисков, ведь класс другой и метод новый (не наследуемый). В этом классе же все методы родителя остаются и можно подставлять объект класса вместо родителя, не пойму в чем потенциальная опасность. Да и в чем тогда смысл наследования если не могу метод добавить)

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

      Если в данном примере мы обращаемся к объекту класса В по интерфейсу класса А, то LSP не нарушается. Потенциально может быть нарушен SRP, если новый метод будет предназначен для взаимодействия с другим актором

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

      Мы не нарушаем - мы потенциально можем его нарушить, но для этого нужно очень постараться.
      Пример, есть 3 класса
      A
      B extends A
      C extends A
      В класс C мы добавляем публичный метод test100500 и в классе-клиенте "завязываемся" на него. После этого - заменить C классом B без рефакторинга мы уже не сможем.

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

      @@EugeneSuleimanov Спасибо за пояснение. Я вроде так и представлял, что в задании имелось в виду. Представлял принцип Лисков, как вместо родителя пихаем наследника, а вместо наследника пихать родителя это ваще что-то другое и так не надо никогда)

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

      @@EugeneSuleimanov Пример хороший, но он не относится к LSP, т.к. B и C не связаны между собой иерархией наследования, а LSP как раз про это

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

      @@LacqueredNoCap но они связаны с классом А, если я не ошибаюсь - это относится к LSP

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

    Спасибо за видео!

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

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

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

    Интересно и познавательно смотреть. Парень неплохо отвечал, но очень сильно посыпался на SQL, там надо либо подучить я думаю, тема не такая сложная, либо просто освежить память т к он хорошо давал ответы на другие более сложные вопросы)

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

    Спасибо

  • @MrRomanvideo
    @MrRomanvideo Год назад +2

    А почему тогда в хешмапе при 0.75 увеличиваем по той же логике, что остальные будут простаивать!? Типа запас на неточность хэшкода!?

    • @EugeneSuleimanov
      @EugeneSuleimanov  Год назад +2

      Потому что при большом количестве заполненных бакетов мы начинаем терять время на поиск бакета для нового хешкода. Поэтому имеет смысл расширять при заполнении 75%.
      В динамическом массиве такой необходимости просто нет :)

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

      @@EugeneSuleimanov а разве индекс банкета не однозначно определяется хэшкодом?

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

      @@MrRomanvideo да, вы правы. Нужно было написать - новый хеш-код :)

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

      Так тут же вопрос производительности. Если делать лод фактор, равный 1, то к моменту заполнения всех корзин мы все чаще будем поучать коллизии. И наоборот, если сделать это значение, например 0,5, то будем терять время на неоправданно частом перестроении структуры. 0,75 - оптимальный коэффициент

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

    Реакция на ответ на 42:26 топ )))

  • @overdrive5772
    @overdrive5772 Год назад +2

    Спасибо за видео, кину мою реализацию алгоритма)
    public static boolean isPalindrome(String s) {
    for (int i = 0; i < s.length() / 2; i++)
    if (s.charAt(i) != s.charAt(s.length() - i - 1))
    return false;
    return true;
    }

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

      Спасибо за отзыв :)

    • @LacqueredNoCap
      @LacqueredNoCap Год назад +3

      Еще нужно не забыть добавить исключение всех небуквенных значений из строки и приведение ее к одному регистру. Я бы сделал стандартно через Java API: String generalizedString = s.toLowerCase().replaceAll("[^a-z]", "");

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

      @@LacqueredNoCap Вообще написано, что эти чары содержат как буквы, так и числа.
      Objects.requireNonNull(s);
      String result = s.toLowerCase()
      .replaceAll("[^a-z0-9]", "");
      if (result.isEmpty() || result.length() == 1) {
      return true;
      }
      return new StringBuilder(result)
      .reverse()
      .toString()
      .equals(result);
      Ну или можно сделать с циклом, первое решение с ним и сделал.
      Я когда решение парня увидел, подумал, что может я чего-то не понял и нагородил xD Ан нет)

  • @ВадимБеляев-щ3й
    @ВадимБеляев-щ3й Год назад

    Есть пара вопросов к реализации проверки на палиндром. Или я чего-то не понимаю, или нет перехода к единому регистру, ведь по условию 'f' и 'F' -- одинаковые буквы, но в вашей реализации они будут считаться различными. Также, по первому примеру видно, что пробельные символы вообще учитываться не должны, но в вашей реализации это не учитывается, т.е., я предполагаю, что на первый пример будет выведено false даже если бы в нём все буквы были одного регистра

  • @ДмитрийКаськив-ы7ч

    Вопрос: каков ваш фидбек? На момент интервью вы бы взяли такого инженера на позицию Junior, если нет то что нужно подтянуть, мне почему то кажется что до февраля 2022 с таким уровнем и на junior+ можно было устроиться, сейчас требования растут постоянно.

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

      На позицию trainee-junior позицию вполне можно брать кандидата. Немного подтянуть некоторые моменты - и можно было бы ставить на проект.

  • @user-hedonist2020
    @user-hedonist2020 Год назад

    Евгений, частные уроки даёте?

    • @EugeneSuleimanov
      @EugeneSuleimanov  Год назад +2

      "Ответил в ЛС" © :)
      Если серьезно - напишите. пожалуйста, на почту proselytear@yahoo.com или telegram: @proselyte
      Сможем обсудить более детально.

  • @engend3405
    @engend3405 Год назад +3

    Топ )
    20:24:00 поправь плз )

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

      Сделано, спасибо за исправление :)

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

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

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

      Конечно - пишите сюда иди в ТГ - попробую помочь :)

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

      @@EugeneSuleimanov СПС. Вопрос будет длинный

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

    это собеседование джуна :?

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

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

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

    Hi! Good job 👍 It’s interesting 😎

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

    мое убогое решение😪
    class Palindrome {
    public static boolean isPalindrome(String str) {
    Pattern pattern = Pattern.compile("\\w");
    Matcher matcher = pattern.matcher(str);
    StringBuilder stringBuilder = new StringBuilder();
    while (matcher.find()) {
    String newStr = matcher.group().toLowerCase();
    stringBuilder.append(newStr);
    }
    String s = stringBuilder.toString();
    for (int i = 0, k = s.length()-1; i < s.length() / 2; i++, k--) {
    if (s.charAt(i) != s.charAt(k))
    return false;
    }
    return true;
    }
    public static void main(String[] args) {
    System.out.println(isPalindrome("A car, A plan: A Panama")); //false
    System.out.println(isPalindrome("A c, A")); //true
    System.out.println(isPalindrome(" ")); //true
    }
    }
    ps. нет времени учить теорию наизусть, ментор задачами заваливает. когда смотрю, как ребята отвечают на вопросы, типа буква О в SOLID грусть, тоска, депрессия подкрадывается, времени не хватает на это учить пока что, но чтобы поднять настроение, вспоминаю, что опытные программисты создавали RUTUBE ))))))

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

      Спасибо за комментарий!
      Если мы выделяем StringBuilder - проще просто вызвать у него reverse и сравнить строки после удаления «лишних» символов :)

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

      @@EugeneSuleimanov сорян, стараюсь руку набить на Pattern/Matcher)

  • @a.e.9880
    @a.e.9880 Год назад +1

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