An open API service indexing awesome lists of open source software.

https://github.com/samgh/Byte-by-Byte-Solutions

Coding interview questions and solutions
https://github.com/samgh/Byte-by-Byte-Solutions

bytebybyte cracking-the-coding-interview interview interview-practice interview-prep interview-questions leetcode

Last synced: 7 months ago
JSON representation

Coding interview questions and solutions

Awesome Lists containing this project

README

          

# Byte by Byte Solutions
[Byte by Byte](http://www.byte-by-byte.com) is a coding interview prep website that provides many practice interview questions as well as detailed explanations. This repo contains working, tested code for the solutions on Byte by Byte.

### Contributing
I would love to compile solutions to all of the problems here, as well as offer solutions in different languages. Currently we only have Java solutions but Python, C, or any other languages would be most welcome. Just create a pull request with your changes. And make sure your code includes at least a few tests!

### Index of Questions
* [Median of Arrays](http://www.byte-by-byte.com/median/)
Find the median of two sorted arrays.

* [Priority Queue](http://www.byte-by-byte.com/priorityqueue/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/PriorityQueue.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/PriorityQueue.py))

Implement a Priority Queue.

* [0-1 Knapsack](http://www.byte-by-byte.com/01knapsack/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/Knapsack.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/Knapsack.py))

Given a list of items with values and weights, as well as a max weight, find the maximum value you can generate from items where the sum of the weights is less than the max.

* [Matrix Product](http://www.byte-by-byte.com/matrixproduct/)
([Github](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/MatrixProduct.java))

Given a matrix, find the path from top left to bottom right with the greatest product by moving only down and right.

* [Find Duplicates](http://www.byte-by-byte.com/findduplicates/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/FindDuplicates.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/FindDuplicates.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/FindDuplicates.py))

Given an array of integers where each value `1 <= x <= len(array)`, write a function that finds all the duplicates in the array.

* [Integer to Roman Numeral](http://www.byte-by-byte.com/inttoroman/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/IntToRoman.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/IntToRoman.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/pythopython/IntToRoman.py))

([Php](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/php/IntToRoman.php))

Given an integer, write a function to return its roman numeral representation.

* [Autocomplete](http://www.byte-by-byte.com/autocomplete/) ([Github](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/Autocomplete.java))
Write an autocomplete class that returns all dictionary words with a given prefix.

* [Linked List Cycle](http://www.byte-by-byte.com/listcycles/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/LinkedListCycle.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/LinkedListCycle.py))

Given a linked list, determine whether it contains a cycle.

* [Build Order](http://www.byte-by-byte.com/buildorder/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/BuildOrder.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/BuildOrder.py))

Given a list of packages that need to be built and the dependencies for each package, determine a valid order in which to build the packages.

* [Consecutive Array](http://www.byte-by-byte.com/consecutivearray/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/ConsecutiveArray.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/ConsecutiveArray.py))

Given an unsorted array, find the length of the longest sequence of consecutive numbers in the array.

* [Zero Matrix](http://www.byte-by-byte.com/zeromatrix/) ([Github](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/ZeroMatrix.java))
Given a boolean matrix, update it so that if any cell is true, all the cells in that row and column are true.

* [Random Binary Tree](http://www.byte-by-byte.com/randombinarytree/) ([Github](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/RandomTree.java))
Implement a binary tree with a method getRandomNode() that returns a random node.

* [Two Missing Numbers](http://www.byte-by-byte.com/twomissingnumbers/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/TwoMissingNumbers.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/TwoMissingNumbers.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/TwoMissingNumbers.py))

Given an array containing all the numbers from 1 to n except two, find the two missing numbers.

* [Shortest Path](http://www.byte-by-byte.com/shortestpath/) ([Github](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/ShortestPath.java))
Given a directed graph, find the shortest path between two nodes if one exists.

* [Square Submatrix](http://www.byte-by-byte.com/squaresubmatrix/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/SquareSubmatrix.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/SquareSubmatrix.py))

Given a 2D array of 1s and 0s, find the largest square subarray of all 1s.

* [Random Linked List](http://www.byte-by-byte.com/randomlinkedlist/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/RandomLinkedList.java))

Given a linked list where each node has two pointers, one to the next node and one to a random node in the list, clone the linked list.

* [Big Int Mod](http://www.byte-by-byte.com/bigintmod/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/BigIntMod.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/BigIntMod.py))

Given a list of bytes `a`, each representing one byte of a larger integer (ie. `{0x12, 0x34, 0x56, 0x78}` represents the integer `0x12345678`), and an integer `b`, find `a % b`.

* [Merge K Arrays](http://www.byte-by-byte.com/mergekarrays/)
Given k sorted arrays, merge them into a single sorted array.

* [Dedup Linked List](http://www.byte-by-byte.com/deduplinkedlist/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/DedupLinkedList.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/DedupLinkedList.py))

Given an unsorted linked list, write a function to remove all the duplicates.

* [Lowest Common Ancestor](http://www.byte-by-byte.com/lowestcommonancestor/)
Given two nodes in a binary tree, write a function to find the lowest common ancestor.

* [String Deletion](http://www.byte-by-byte.com/stringdeletion/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/StringDeletion.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/StringDeletion.py))

Given a string and a dictionary HashSet, write a function to determine the minimum number of characters to delete to make a word.

* [Sum](http://www.byte-by-byte.com/sum/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/Sum.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/Sum.py))

Given two integers, write a function to sum the numbers without using any arithmetic operators.

* [Reverse Stack](http://www.byte-by-byte.com/reversestack/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/ReverseStack.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/ReverseStack.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/ReverseStack.py))

Given a stack, reverse the items without creating any additional data structures.

* [Swap Variables](http://www.byte-by-byte.com/swapvariables/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/SwapVariables.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/SwapVariables.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/SwapVariables.py))

Given two integers, write a function that swaps them without using any temporary variables.

* [Matrix Search](http://www.byte-by-byte.com/matrixsearch/)
Given an `n x m` array where all rows and columns are in sorted order, write a function to determine whether the array contains an element `x`.

* [Clock Angle](http://www.byte-by-byte.com/clockangle/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/ClockAngle.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/ClockAngle.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/ClockAngle.py))

Given two integers, an hour and a minute, write a function to calculate the angle between the two hands on a clock representing that time.

* [Fibonacci](http://www.byte-by-byte.com/fibonacci/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/Fibonacci.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/Fibonacci.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/Fibonacci.py))

Given an integer n, write a function to compute the nth Fibonacci number.

* [Tree to Doubly Linked List](http://www.byte-by-byte.com/treetolist/)
Given a tree, write a function to convert it into a circular doubly linked list from left to right by only modifying the existing pointers.

* [Line Intersection](http://www.byte-by-byte.com/lineintersection/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/LineIntersection.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/LineIntersection.py))

Given two lines on a Cartesian plane, write a function to determine whether or not the lines intersect.

* [Longest Consecutive Branch](http://www.byte-by-byte.com/longestbranch/)
Given a tree, write a function to find the length of the longest branch of nodes in increasing consecutive order.

* [Sort Stacks](http://www.byte-by-byte.com/sortstacks/)
Given a stack, sort the elements in the stack using one additional stack.

* [Print Reversed List](http://www.byte-by-byte.com/printreversedlist/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/PrintReversedList.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/PrintReversedList.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/PrintReversedList.py))

Given a linked list, write a function that prints the nodes of the list in reverse order.

* [Longest Common Substring](http://www.byte-by-byte.com/longestsubstring/)
Given two strings, write a function that returns the longest common substring.

* [Stack from Queues](http://www.byte-by-byte.com/stackfromqueues/)
Implement a LIFO stack with basic functionality (push and pop) using FIFO queues to store the data.

* [Balanced Binary Tree](http://www.byte-by-byte.com/balancedtree/)
Given a binary tree, write a function to determine whether the tree is balanced.

* [Gray Code](http://www.byte-by-byte.com/graycode/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/GrayCode.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/GrayCode.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/GrayCode.py))

Given two integers, write a function to determine whether or not their binary representations differ by a single bit.

* [Merge Arrays](http://www.byte-by-byte.com/mergearrays/)
Given 2 sorted arrays, A and B, where A is long enough to hold the contents of A and B, write a function to copy the contents of B into A without using any buffer or additional memory.

* [Zero Sum Subarray](http://www.byte-by-byte.com/zerosum/)
Given an array, write a function to find any subarray that sums to zero, if one exists.

* [Three Sum](http://www.byte-by-byte.com/threesum/)
Given a list of integers, write a function that returns all sets of 3 numbers in the list, `a`, `b`, and `c`, so that `a + b + c == 0`.

* [Rotate Bits](http://www.byte-by-byte.com/rotatebits/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/RotateBits.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/RotateBits.py))

Given a number, write a function to rotate the bits (ie circular shift).

* [Palindromes](http://www.byte-by-byte.com/palindromes/)
Given a linked list, write a function to determine whether the list is a palindrome.

* [Permutations](http://www.byte-by-byte.com/permutations/)
Write a function that returns all permutations of a given list.

* [N Stacks](http://www.byte-by-byte.com/nstacks/)
Implement N > 0 stacks using a single array to store all stack data (you may use auxiliary arrays in your stack object, but all of the objects in all of the stacks must be in the same array). No stack should be full unless the entire array is full.

* [Tree Level Order](http://www.byte-by-byte.com/treelevelorder/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/TreeLevelOrder.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/TreeLevelOrder.py))

Given a tree, write a function that prints out the nodes of the tree in level order.

* [Split Linked List](http://www.byte-by-byte.com/splitlinkedlist/)
Given a linked list, write a function to split the list into two equal halves.

* [Kth Most Frequest String](http://www.byte-by-byte.com/kthmostfrequentstring/)
Given a list of strings, write a function to get the kth most frequently occurring string.

* [String Compression](http://www.byte-by-byte.com/stringcompression/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/StringCompression.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/StringCompression.py))

Given a string, write a function to compress it by shortening every sequence of the same character to that character followed by the number of repetitions. If the compressed string is longer than the original, you should return the original string.

* [Anagrams](http://www.byte-by-byte.com/anagrams/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/Anagrams.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/Anagrams.py))

Given two strings, write a function to determine whether they are anagrams.

* [Binary Search Tree Verification](http://www.byte-by-byte.com/binarysearchtree/)
Given a binary tree, write a function to test if the tree is a binary search tree.

* [Max Stack](http://www.byte-by-byte.com/maxstack/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/MaxStack.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/MaxStack.py))

Implement a LIFO stack that has a `push()`, `pop()`, and `max()` function, where `max()` returns the maximum value in the stack. All of these functions should run in `O(1)` time.

* [Number of Ones in Binary](http://www.byte-by-byte.com/onesinbinary/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/OnesInBinary.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/OnesInBinary.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/OnesInBinary.py))

Given an integer, write a function to compute the number of ones in the binary representation of the number.

* [Smallest Change](http://www.byte-by-byte.com/smallestchange/)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/SmallestChange.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/SmallestChange.py))

Given an input amount of change `x`, write a function to determine the minimum number of coins required to make that amount of change.

* [Nth-to-last Element](http://www.byte-by-byte.com/nthtolastelement)
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/NthToLast.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/NthToLast.py))

Given a linked list, and an input n, write a function that returns the nth-to-last element of the linked list.

* [FizzBuzz](http://www.byte-by-byte.com/fizzbuzz/)
([C++](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/cpp/FizzBuzz.cpp))
([Java](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/java/FizzBuzz.java))
([Python](https://github.com/samgh/Byte-by-Byte-Solutions/blob/master/python/FizzBuzz.py))

Output numbers from `1` to `x`. If the number is divisible by `3`, replace it with `“Fizz”`. If it is divisible by `5`, replace it with `“Buzz”`. If it is divisible by `3` and `5` replace it with `“FizzBuzz”`.