This repo is intended for any individual wanting to improve their problem solving skills for software engineering interviews.
Problems are grouped under their respective subtopic, in order to focus on repeatedly applying common patterns rather than randomly tackling questions.
All questions are available on leetcode.com with some requiring leetcode premium.
To find the greatest amount of success when practicing, it is highly recommended to know the methods and runtimes of the following data structures and their operations:
- Arrays
- Maps
- Linked Lists
- Queues
- Heaps
- Stacks
- Trees
- Graphs
In addition, you should have a good grasp on common algorithms such as:
- Breadth-first search
- Depth-first search
- Binary search
- Recursion
This pdf contains information for the main data structures in Java.
Other useful methods to know include substring(), toCharArray(), Math.max(),
Math.min(), and Arrays.fill().
The entire question list can be found here: https://seanprashad.com/leetcode-patterns/.
Solutions written in Java can be found in the solutions branch.
The app is built with Next.js (App Router), React 19, TypeScript, Tailwind CSS v4, TanStack Table v8, Lucide React for icons, and Google Analytics via @next/third-parties. Tests use Vitest + React Testing Library.
npm install
npm run dev # http://localhost:3000
npm test # single run
npm run test:watch # watch modeA Husky pre-push hook runs npm test automatically before every push. This is set up for every clone via the prepare script.
This list is heavily inspired from Grokking the Coding Interview with additional problems extracted from the Blind 75 list and this hackernoon article on 14 patterns to ace any coding interview question.