Skip to content

A mostly reasonable collection of technical software development interview questions solved in Javascript

License

Notifications You must be signed in to change notification settings

astonm/interview-questions-in-javascript

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 

Repository files navigation

Interview Algorithm Questions in Javascript() {...}

A mostly reasonable collection of technical software development interview questions solved in Javascript in ES5 and ES6

Table of Contents

  1. Array
  2. Strings
  3. Stacks and Queues
  4. Logic Riddles
  5. Recursion
  6. To Be Continued

Array

  • 1.1 Given an array of integers, find the largest product yielded from three of the integers
    var unsorted_array = [-10, 7, 29, 30, 5, -10, -70];
    
    computeProduct(unsorted_array); // 21000
    
    function sortIntegers(a, b) {
      return a - b;
    }
    
    // greatest product is either (min1 * min2 * max1 || max1 * max2 * max3)
    function computeProduct(unsorted) {
      var sorted_array = unsorted.sort(sortIntegers),
        product1 = 1,
        product2 = 1,
        array_n_element = sorted_array.length - 1;
    
      // Get the product of three largest integers in sorted array
      for (var x = array_n_element; x > array_n_element - 3; x--) {
          product1 = product1 * sorted_array[x];
      }
      product2 = sorted_array[0] * sorted_array[1] * sorted_array[array_n_element];
    
      if (product1 > product2) return product1;
      
      return product2
    };

  • 1.2 Being told that a unsorted array contains (n - 1) of n consecutive numbers (where the bounds are defined), find the missing number in O(n) time
    // The output of the function should be 8
    var array_of_integers = [2, 5, 1, 4, 9, 6, 3, 7];
    var upper_bound = 9;
    var lower_bound = 1;
    
    findMissingNumber(array_of_integers, upper_bound, lower_bound); //8
    
    function findMissingNumber(array_of_integers, upper_bound, lower_bound) {
      
      // Iterate through array to find the sum of the numbers
      var sum_of_integers = 0;
      for (var i = 0; i < array_of_integers.length; i++) {
        sum_of_integers += array_of_integers[i];
      }
      
      // Find theoretical sum of the consecutive numbers using a variation of Gauss Sum. 
      // Formula: [(N * (N + 1)) / 2] - [(M * (M - 1)) / 2]; 
      // N is the upper bound and M is the lower bound
      
      upper_limit_sum = (upper_bound * (upper_bound + 1)) / 2;
      lower_limit_sum = (lower_bound * (lower_bound - 1)) / 2;
      
      theoretical_sum = upper_limit_sum - lower_limit_sum;
      
      // 
      return (theoretical_sum - sum_of_integers)
    }

  • 1.3 Removing duplicates of an array and returning an array of only unique elements
    // ES6 Implementation
    var array = [1, 2, 3, 5, 1, 5, 9, 1, 2, 8];
    
    Array.from(new Set(array)); // [1, 2, 3, 5, 9, 8]
    
    
    // ES5 Implementation
    var array = [1, 2, 3, 5, 1, 5, 9, 1, 2, 8];
    
    uniqueArray(array); // [1, 2, 3, 5, 9, 8]
    
    function uniqueArray(array) {
      var hashmap = {};
      var unique = [];
      for(var i = 0; i < array.length; i++) {
        // If key returns null (unique), it is evaluated as false. 
        if(!hashmap.hasOwnProperty([array[i]])) {
          hashmap[array[i]] = 1;
          unique.push(array[i]);
        }
      }
      return unique;
    }

⬆ back to top

Strings

  • 2.1 Given an string, reverse each word in the sentence
    "Welcome to this Javascript Guide!" should be become "emocleW ot siht tpircsavaJ !ediuG"
    var string = "Welcome to this Javascript Guide!";
    
    // Output becomes !ediuG tpircsavaJ siht ot emocleW 
    var reverse_entire_sentence = reverseBySeperator(string, "");
    
    // Output becomes emocleW ot siht tpircsavaJ !ediuG
    var reverse_each_word = reverseBySeperator(reverse_entire_sentence, " ");
    
    function reverseBySeperator(string, seperator) {
      return string.split(seperator).reverse().join(seperator);
    }

  • 2.2 Given a two string, return true if they are anagrams of one another "Mary" is an anagram of "Army"
    var first_word = "Mary";
    var second_word = "Army";
    
    isAnagram(first_word, second_word); //true
    
    function isAnagram (first, second) {
    
      // For case insensitivity, change both words to lowercase.
      var a = first.toLowerCase();
      var b = second.toLowerCase();
      
      // Sort the strings, and join the resulting array to a string. Compare the results
      a = a.split("").sort().join("");
      b = b.split("").sort().join("");
      
      return (a === b);
    }

  • 2.3 Check if a given string is a palindrome
    "racecar" is a palindrome. "race car" should also be considered a palindrome. Case sensitivity should be taken into account
    isPalindrome("racecar"); // true
    isPalindrome("race Car"); // true
      
    function isPalindrome(word) {
      // Replace all non-letter chars with "" and change to lowercase
      var letters_only = word.replace(/[^a-z]+/g,"");
      letters_only = letters_only.toLowerCase();
      
      // Compare the string with the reversed version of the string
      return (letters_only === letters_only.split("").reverse().join(""));
    }

⬆ back to top

Stacks and Queues

  • 3.1 Implement enqueue and dequeue using only two stacks
    var input_stack = []; // first stack
    var output_stack = []; // second stack
    
    // For enqueue, just push the item into the first stack
    function enqueue(stack_input, item) {
      return stack_input.push(input);
    }
    
    function dequeue(stack_input, stack_output) {
      // Reverse the stack such that the first element of the output stack is the
      // last element of the input stack. After that, pop the top of the output to 
      // get the first element that was ever pushed into the input stack
      if (stack_output.length <= 0) {
        while(stack_input.length > 0) {
          var element_to_output = stack_input.pop();
          stack_output.push(element_to_output);
        }
        return stack_output.pop();
      }
    }

  • 3.2 Create a function that will evaluate if a given expression has balanced parentheses
    In this example, we will only consider "{}" as valid parentheses {}{} would be considered balancing. {{{}} is not balanced
    var expression = "{{}}{}{}"
    var expression_false = "{}{{}";
    
    isBalanced(expression); // true
    isBalanced(expression_false); //false
    isBalanced(""); // true
    
    function isBalanced(expression) {
      var check_string = expression;
      var stack = [];
    
      // If empty, parentheses are technically balanced
      if (check_string.length <= 0) return true
    	
      for (var i = 0; i < check_string.length; i++) {
        if(check_string[i] === '{') {
          stack.push(check_string[i]);
        } else if (check_string[i] === '}') {
          // pop on an empty array is undefined
          if (stack.pop()) {
            stack.pop();
          } else {
            return false;
          }
        }
      }
      
      // If the array is not empty, it is not balanced
      if (stack.pop()) return false;
      return true;
    }

⬆ back to top

Logic Riddles

  • 4.1 Two ropes and a lighter.
    You are presented with two ropes and a lighter. The rope is rather strange as the density is different throughout the rope, and will not burn consistently. Knowing that each rope takes 1 hour to burn, how can you find that 45 minutes has passed?

    Start by taking the first rope and lighting both ends. By doing so, you know that the rope 
    will be completely burnt in 30 minutes. At the same time, light the second rope on one end. 
    Once the first rope has completely burnt out, light the other end of the second rope. When 
    both ropes are burnt out, 45 minutes has passed
    

⬆ back to top

Recursion

  • 5.1 Write a recursive function that return the binary string of a given decimal number
    Given 4 as the decimal input, the function should return 100

    decimalToBinary(8) //1000
    
    function decimalToBinary(digit) {
      if (n >= 1) {
        // recursively return proceeding binary digits
        return decimalToBinary(digit / 2) + (digit % 2).toString();
      } else {
        // exit condition
        return "";
      }
    }

⬆ back to top

About

A mostly reasonable collection of technical software development interview questions solved in Javascript

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published