Javascript Coding Interview Questions- You Must Know Them

แชร์
ฝัง
  • เผยแพร่เมื่อ 26 ม.ค. 2025

ความคิดเห็น • 71

  • @MonsterlessonsAcademy
    @MonsterlessonsAcademy  4 หลายเดือนก่อน

    WATCH NEXT: Javascript Interview Questions and Answers - Dominate Your Next Interview - th-cam.com/video/wnYKH2dO620/w-d-xo.htmlsi=5DfbGEfhXWiiv0a_

  • @Vivek-Nishad
    @Vivek-Nishad ปีที่แล้ว +10

    Object.assign and spread operator only work it you have a flat object like {a:1, b:2} But if you have nested object like {a:1,b:2,c:{d:3}} it will copy value of a and b but reference of c,d.
    so, if you want to copy nested objects you can use "structuredClone(obj)" or "JSON.parse(JSON.stringify(obj))"

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว +2

      You are totally right

    • @vishalupadhayay6391
      @vishalupadhayay6391 ปีที่แล้ว +1

      JSON.parse(JSON.stringify(obj)) will not work if the object has Arrays, Functions, and Date nested within. In such a scenario, we may have to use loadash or write one custom function to handle Arrays, Functions, and Date objects.

    • @KAZVorpal
      @KAZVorpal 5 หลายเดือนก่อน +2

      I was here to specifically raise the same objection.
      But if I were an interviewer, I might be wanting an answer that showed understanding of the LOGIC of cloning.
      In other words, a recursive function that checks if the passed value is an object, returns it if not, but if it is, loops through its properties and calls ITSELF on each property that is an object, gradually building a new object, then returns the final product.
      I would not be satisfied with someone just using structuredClone() because I'd want to see their coding/algorithmic knowledge.

  • @AndreaDragotta
    @AndreaDragotta ปีที่แล้ว +5

    Regarding the clone example, be aware that these are shallow copies (they do not work correctly when the object contains other objects). If you need a deep copy you should use the new "structuredClone" api or the usual trick with "JSON.parse(JSON.stringify(obj))"

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว +1

      I have a full video about shallow comparison vs deep comparison.
      th-cam.com/video/re0G89DwOb8/w-d-xo.htmlsi=snVLRIAqpU0_5OuN

  • @SuperMatsumoto23
    @SuperMatsumoto23 ปีที่แล้ว +8

    I am sooo grateful for this video!! I am a junior developer currently preparing for my tech interviews, and some of this stuff was difficult to understand while just reading a text explanation. Thank you for showing these examples step by step, these have helped me get a better understanding of the theory. ♥

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว

      Glato to hear that. For interview preparation you might be interested in my Javascript interview questions course where you learn 56 different topics which fully cover Javascript.
      monsterlessons-academy.com/courses/javascript-interview-questions-coding-interview/

    • @francescaperfume
      @francescaperfume 6 หลายเดือนก่อน

      😊​@@MonsterlessonsAcademy

    • @francescaperfume
      @francescaperfume 6 หลายเดือนก่อน

      ​@@MonsterlessonsAcademy😊

    • @francescaperfume
      @francescaperfume 6 หลายเดือนก่อน

      ​@@MonsterlessonsAcademy😊

    • @francescaperfume
      @francescaperfume 6 หลายเดือนก่อน

      ​@@MonsterlessonsAcademy😊

  • @n_fan329
    @n_fan329 ปีที่แล้ว +1

    for the last question..we can also do Object.entries(mapping).sort((a,b)=>a

  • @joeldaros
    @joeldaros 2 ปีที่แล้ว +2

    I really like your videos, you get straight to the point. Please make more videos like this one!

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 ปีที่แล้ว +1

      I have now a full course of 59 coding exercises for Javascript interview.
      monsterlessons-academy.com/courses/javascript-interview-questions-coding-interview

  • @jonathanjohnson2785
    @jonathanjohnson2785 ปีที่แล้ว +1

    I don't have words to fully express my gratitude. Closures, cloning are things I found hard to understand but your style of teaching made everything so simple to understand. Thank you so much and all the best❤👍👍👏

  • @bendevweb89
    @bendevweb89 2 ปีที่แล้ว +1

    As a Junior Developer your content helps me a lot to prepare for interviews and improve my logic
    Thank you very much 👍

  • @mohammadyousuf1567
    @mohammadyousuf1567 2 ปีที่แล้ว

    I am addicted to your style of teaching .. : )

  • @Ttlwar
    @Ttlwar 3 วันที่ผ่านมา

    all good tell you started reducing a reduce of object key value pairs

  • @dragosp.7635
    @dragosp.7635 2 ปีที่แล้ว

    at 3:50. I see it also work const clone=object. Is it a good practice?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 ปีที่แล้ว +1

      It is not. You assign the reference to the object and not a new object with a value. Try to change property of clone and check the value of both objects.

  • @damienspectre4231
    @damienspectre4231 ปีที่แล้ว +1

    For the first problem - I understand closures and you are returning a fucntion within the parent function that returns the secret. but Im curious - why not return the secret string directly instead of within the child function? its a const and its private to the someFn() and cant be modified once declared...

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว +1

      It was just an example to show closures. environment variables should not be written in code in any case.

  • @dmytro-skh
    @dmytro-skh ปีที่แล้ว +4

    as for me reduce in the last example is too complicated to understand and debug. Nice for an interview but I would avoid such things in real code. I.e. if jun dev will have to work with that piece of code. In general good video, will look others on the channel too :)

    • @keneldridge
      @keneldridge ปีที่แล้ว

      I like Object.keys(counterObject).sort((a,b) => { return a > b ? -1 : 0 })[0]

  • @orz5516
    @orz5516 ปีที่แล้ว

    In the findVowels i would expect a senior developer would do it with an object because with includes that complexity is much higher.
    With an object you can just iterate the string once and check each time if the char is a vowel with O(1) complexity

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว +4

      There are different ways. Object is also not ideal. Regexr is easier that
      const vowelCount = str => {
      const regex = /[aeiouAEIOU]/g
      const s = str.match(regex)
      return s ? s.length : 0
      }

    • @orz5516
      @orz5516 ปีที่แล้ว

      @@MonsterlessonsAcademy
      And thanks for the videos, you are great!

  • @clement2814
    @clement2814 2 ปีที่แล้ว

    Thank you, clear and concise

  • @leojohn6702
    @leojohn6702 ปีที่แล้ว

    Quick question. Currently building my portfolio projects. But I have no knowledge of data structures and algorithms. Should i start training after my portfolio will be completed? Or prior the portfolio?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว +2

      Do a portfolio, CV and then improve your knowledge and add it. If you are a junior forget about data structures and algorithms at all. learn language and framework.

  • @OliaYarukhina
    @OliaYarukhina ปีที่แล้ว

    Круто! Дякую! Цікаво звідки Ви, Олександре?)

  • @yeti9537
    @yeti9537 3 ปีที่แล้ว

    This is great. Thanks!

  • @Shivam-sl4sp
    @Shivam-sl4sp ปีที่แล้ว

    Thank you man !!

  • @jjjj5452
    @jjjj5452 ปีที่แล้ว

    Now just need to get an interview that asks one of these 5 questions...

  • @cryptopinky2355
    @cryptopinky2355 ปีที่แล้ว

    Why do we write acc[1] and el[1]? what is the index for and why is it always 1?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  ปีที่แล้ว

      Because there are just 2 elements in the array and we want to work with the second one.

  • @amitkrishna2412
    @amitkrishna2412 2 ปีที่แล้ว

    Hi , Is there a document or a list of such interview questions that you have maintained?which I can follow?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 ปีที่แล้ว +1

      No I don't have something like this. But I have a full course with 57 Javascript questions which covers all knowledge that you need.
      monsterlessons-academy.com/courses/javascript-interview-questions-coding-interview

  • @testify7228
    @testify7228 2 ปีที่แล้ว

    Hi,
    For last question
    To get element which have max occurrence:
    After creating object, can we use .sort() nd do descending order based on Occurance nd then return first value from sorted object.
    Is it correct?

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 ปีที่แล้ว

      Hi, There are different ways to solve the same task.

    • @testify7228
      @testify7228 2 ปีที่แล้ว

      @@MonsterlessonsAcademy ok dude. Thanks for replay
      I saw ur 59 interview questions video course, really worth fir spending time in it

  • @n_fan329
    @n_fan329 18 วันที่ผ่านมา

    last question :
    et tab=['nabil','adil','fatima','nabil','fatima','assiya','hakima','nabil'];
    let obj={}
    tab.forEach(string=>{
    obj[string] ? obj[string]++ : obj[string]=1
    });
    let final= Object.entries(obj);
    console.log(final.sort((a,b)=>b[1]-a[1])[0][0]) // nabil

  • @sameoldsteven9571
    @sameoldsteven9571 ปีที่แล้ว

    cant we solve the last question using Set?

  • @doniaelfouly4142
    @doniaelfouly4142 ปีที่แล้ว

    thank you so much

  • @AndrewTSq
    @AndrewTSq 2 ปีที่แล้ว +1

    The count vowels i just did [...str.toLowerCase().matchAll(/[aeiou]/g)].length not sure it was right, but worked on my examples :) fun questions :)

  • @_Greenflag_
    @_Greenflag_ 2 หลายเดือนก่อน +1

    Not good. Be careful when labeling other versions as "beginner" if your own code is not good, performant, or clean (and be careful when you label a version as "more advanced" when it's only a question of syntax). There is absolutely nothing wrong with the code commented at 8:20 (except for using "let char" instead of "const char"). Your version is less performant than the "beginner" version; the reduce function has higher space and time complexity. 9:20 no, this is not good at all. Space and time complexity are f. up. Correction, just iterate once over all array :
    function reverseString(str: string) {
    let result = '';
    for (let i = str.length - 1; i >= 0; i--) {
    result += str[i];
    }
    return result;
    }
    const reversed = reverseString('hello');
    Last exercice, the worst of your serie. Time / space complexity f. up, and way too much code. Correction:
    function mostCommonString(strings: string[]): string {
    const hashMap: { [element: string]: number } = {};
    let maxElement = strings[0];
    let maxValue = 0;
    for (const element of strings) {
    hashMap[element] = (hashMap[element] || 0) + 1;
    if (hashMap[element] > maxValue) {
    maxValue = hashMap[element];
    maxElement = element;
    }
    }
    return maxElement;
    }

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  2 หลายเดือนก่อน +1

      Performance doesn't mean everything. 90% of the time readability is more important to make your code maintainable. If your code runs on 100 records it doesn't matter what's inside. Premature optimisations are not needed. Fix performance when it becomes a problem.

  • @sliceem88
    @sliceem88 3 ปีที่แล้ว

    Best !

  • @KAZVorpal
    @KAZVorpal 5 หลายเดือนก่อน +1

    NOOO!
    Do not count all the strings, then SEPARATELY find the largest with a second reduce. How wasteful.
    Mark the highest all along, saving you an extra loop.
    Like this:
    const max = {name: "", count:0}
    target.reduce((namelist, name) => {
    if(namelist.has(name)) {
    const current = namelist.get(name)+1;
    namelist.set(name, current);
    (current > max.count) && ([max.name, max.count] = [name, current]);
    } else
    namelist.set(name, 1);
    return namelist;
    }, new Map);
    return max;

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  5 หลายเดือนก่อน

      It depends on the size of the array. 2 functions are less performant but more readable. But if we work with 10 element then who cares.

    • @KAZVorpal
      @KAZVorpal 5 หลายเดือนก่อน

      @@MonsterlessonsAcademy If done clearly, it's actually more readable as a single function.
      More importantly, it's better to impress the interviewer with how well you code as a JOB...and the better performance of doing it as a single loop would be far better in many situations where you're working with a large amount of data.
      Your code should be elegant and efficient, not just the most basic expression.

  • @thisisryker
    @thisisryker 4 หลายเดือนก่อน

    why using .reduce() is better ? You telling to use .reduce() is better, but never explain why.

    • @MonsterlessonsAcademy
      @MonsterlessonsAcademy  4 หลายเดือนก่อน

      reduce is a functional and declarative way of writing code in comparison to for loops. It returns the direct result, avoids creating additional variables before and doesn't have side effects.