ОГОНЬ Задача с моего ПЕРВОГО собеседования на Junior Frontend Developer

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

КОМЕНТАРІ • 60

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

    Забыл в задаче указать в 11 строчке - вызови метод join(" ") после reduce - чтобы получить - 'лон ес'

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

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

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

      Спасибо 🚀❤️

  • @АраАкобян-ч1д
    @АраАкобян-ч1д Рік тому

    интересная задача, хорошо, что вы рассказали

  • @alexandroppolus
    @alexandroppolus Рік тому +33

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

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

      100%. Я ни разу такого потом подобного не встречал. Компания небольшая была. Чел который меня собесил закончил МФТИ, так что мне еще тогда повезло с заданием

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

      😄 точно

  • @MirrorWorlds-
    @MirrorWorlds- 9 місяців тому +2

    условие первой задачи было вывести строку "лон ес" а у Вас в конце получился массив с элементами "лон" и "ес". Задание выполнено не доконца...
    Решение первой задачи одной строкой
    str.split(', ').filter((_, i) => i % 2).map(val => val.substr(1)).join(' ');

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

      Отлично молодец 👍🏼

  • @hackzem07
    @hackzem07 9 місяців тому +1

    Для фибоначчи можно сделать так:
    const fib = (num) => {
    const rfib = (num, acc = 0, acc2 = 1) => {
    if (num

    • @ПожилойБилибоба
      @ПожилойБилибоба 4 місяці тому

      Рекурсия потребляет больше ресурсов, поэтому лучше через цикл решать

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

    Вместо промисов можно было async await, я думаю, использовать. Они тоже промис возвращают

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

    JavaScript-изеры вперед)

  • @Roman-qr4xg
    @Roman-qr4xg Рік тому +2

    Было бы интересно услышать историю как сменили профессию на fronted разработчика,как учились, сколько времени занял путь до 🍅

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

      Ага, сделаю обязательно, но чуточку позже🫶

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

    отличное видео

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

    Я немного не понял почему в числах Фибоначчи f1 = 1 и f2 = 1? Поидее первое число f1 должно равняться 0, а второе f2 равно 1

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

      Ага тут есть несколько вариантов, зависит от источника литературы. Мы опускаем F0 и счет ведем с F1.
      Цитата из Википедии:
      Правда, в некоторых книгах, особенно в старых, член
      F
      0
      F_{0}, равный нулю, опускается - тогда последовательность Фибоначчи начинается с
      F
      1
      =
      F
      2
      =
      1
      {\displaystyle F_{1}=F_{2}=1}[5][6].

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

    подскажите плагин, который вам подсказывает, как называется ?

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

      Tabnine

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

      Насколько же это удобно…
      Огромное спасибо.

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

    а не проще ли было асинхронную часть сделать через asinc/await ?

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

      Нет. Это собес. Там не спрашивают про async await

  • @АндрейРосовский

    Интересно, нужно было именно через промисы делать или async/await тоже засчитали бы?

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

      Я думаю их интересовала тема промисов, понимание самой конструкции

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

      async await это тоже промисы. Просто сахар над ними

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

      @@vladislavstepanov7591 про async/await на собесе спросят в самую последнюю очередь, а вот new Promise - это почти всегда. Решая задачи на собесе, нужно давать интервьюеру то, что он хочет или ожидает от тебя - это залог успеха любого собеса

    • @ЕленаМонастырская-т1л
      @ЕленаМонастырская-т1л Рік тому

      @@agaf89 Вы уверены про последнюю очередь? Мне попадалось.. Если задача звучала как "сделать асинхронность через new Promise", то всё ок, а если просто "сделать асинхронность", то можно и нужно решать задачу оптимальным в своем понимании способом. И async/await здесь бы смотрелся максимально уместно. Если интервьюер хочет какой-то конкретный способ решения, он скажет. А гадать что он там хотел - неблагодарное дело

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

    а как подобное можно было бы решить через async/await?

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

      Навтыкать в двух функциях async - но надо быть готовым решить через промисы

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

    1/5 года опыта, могу ли теперь найти новый проект?

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

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

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

    Произведение это умножение, а Фибоначчи это сумма двух чисел

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

      Да я сделал правку в видео: *сумма

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

      6:21 *сумма

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

    если использовать рекурсию при вычислении числа Фибоначчи и использовать async await то всё решается буквально в 4 строки
    const getSomeData = async (str, num) => [ await getStr(str), await fib(num)]
    const getStr = async (str) => str.split(', ').reduce((acc, val, index) => index % 2 !== 0 ? [...acc, val.slice(1, val.length)] : acc, []).join(' ')
    const fib = async (n) => n

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

      Круто, молодец ❤️

    • @js8n35
      @js8n35 10 місяців тому +1

      753 вызова функции fib для того, чтобы вычислить 13 число фибоначи. Такое себе решение

  • @user-mg1mu1sn7z
    @user-mg1mu1sn7z Рік тому

    Что за плагин, который код подсказввает серым?

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

      Tabnine - нейронка обучается, если новый проект, то слабо подсказывает. Платная ПРО версия творит чудеса

    • @user-mg1mu1sn7z
      @user-mg1mu1sn7z Рік тому

      @@agaf89 Как думаешь, новичку следует пользоваться такого рода инструментами или лучше пока набивать руку с обычными снипетами еммета?

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

      @@user-mg1mu1sn7z сложно сказать. Я думаю все таки самому писать, только потом когда уже автоматизм появится, то можно юзать табнайн

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

    👏👍

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

    Оговорился. Не произведение, а сумма соседних чисел

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

      Верно, я это указал в видео *Сумма 👍🏼

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

    Не пойму зачем джуну знать про фибоначи? Разве это хоть когда то пригодится в реальных проектах? Почему не давать тестовые задания которые прямо связанны с реальными задачами? 🥸 Но объяснения хорошие 🙏

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

      Сложно ответить. Знания Фибоначчи это специфические знания. В реальности применения не видел. Но я думаю задача была оценить как джун может выкрутиться из этой ситуации.

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

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

    • @Happy-wt9dy
      @Happy-wt9dy Рік тому

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

  • @ИззатТурсунов
    @ИззатТурсунов Рік тому

    Даже сеньер тут наделал ошибок, поэтому говорить что для Джуна это легко не стоит .

  • @АндрейЛ-щ3э
    @АндрейЛ-щ3э Рік тому +2

    лон ес можно было получить проще.
    const sliced = string.split(', ').filter((el, i)=> i % 2 !== 0).map(el => [...el].slice(1).join('')).join(' ')

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

      выглядить не проще)

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

      глаза сломать можно !))

    • @ЕленаМонастырская-т1л
      @ЕленаМонастырская-т1л Рік тому +3

      Это и нечитабельно и неоптимально, вы делаете два прохода по массиву вместо одного

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

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

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

      Не понимаю

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

    Я бы лучше регуляркой слова вытащил, иначе если будут случайно двойные пробелы, без пробелов или вообще другие символы, то по пизде пойдёт ответ) ну и slice(1) можно просто написать)
    str.match(/[а-яa-z]+/gi)
    .reduce((acc, el, i) => {
    if (i % 2 > 0) {
    acc.push(el.slice(1));
    }
    return acc;
    }, [])
    .join('');

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

      С регуляркой идея интересная, но в коде всё же не учтён один граничный случай. При передаче пустой строки (или не содержащей букв) должна вернуться пустая строка.