Welcome to the OpenLeetCode Project!
The motivation behind this project is to be able to practice LeetCode problems on a plane without requiring an internet connection (until Starlink ramps up). This project is not intended to replace or replicate leetcode.com.
- OpenLeetCode - An open source version of LeetCode
- Table of Content
- Screenshot
- Build
- Run
- How To Use
- List of LeetCode Problems
- Usage
- Note
- Requirements - Additional Requirements for the UI
- Contributing
git clone https://github.com/mbucko/openleetcode
cd openleetcode
.\install --prefix=./install
git clone https://github.com/mbucko/openleetcode
cd openleetcode
.\install --prefix=./install --enable_ui
git clone https://github.com/mbucko/openleetcode
cd openleetcode
./install.sh --prefix=./install
git clone https://github.com/mbucko/openleetcode
cd openleetcode
./install.sh --prefix=./install --enable_ui
dir install/OpenLeetCode
./openleetcode --language cpp --problem TwoSum
dir install/OpenLeetCode
./openleetcodeui
cd install/OpenLeetCode
./openleetcode.sh --language cpp --problem TwoSum
cd install/OpenLeetCode
./openleetcodeui.sh
NOTE: UI for unix is yet to be tested.
After the build succeeds, the following directory structure will be generated:
- problems
- NumberOfIslands
- cpp
- solution.cpp
- ...
- testcases
- TestCase1.test
- TestCase2.test
- ...
- description.md
- cpp
- TwoSum
- ..
- NumberOfIslands
- launguage
- cpp
Just like for LeetCode, you have one file where you solve the problem. For example, the problem called TwoSum has problems/TwoSum/cpp/solution.cpp. To add new test cases, you can create a file in the problems/TwoSum/testcases/ directory with the file extension .test, and the solution will automatically be tested against it.
Each problem is described in the description.md file location in the problem's directory. For example problems/TwoSum/description.md.
The format of the .test files are as follows:
<arg1>
<arg2>
<expected results>
The supported types are: integral type, a string, TreeNode structure, boolean or an array. For example:
["1", "2", "4"]
8.0
[0, 0]
A ThreeNode structure is represented in an array-based structure. For example an array representation [1, 2, null, null, 3]
results to the following structure:
1
/ \
2 3
- TwoSum
- LongestSubstringWithoutRepeatingCharacters
- NumberOfIslands
- CheckCompletenessOfABinaryTree
The problem names are automatically extracted from the problems folder.
$ python openleetcode.py --help
usage: openleetcode.py [-h] [--language {cpp}] [--list-problems] [--list-testcases] [--problem problem_name] [--problem_builds_dir dir] [--testcase testcase_name] [--verbose]
OpenLeetCode problem builder. This script builds and tests LeetCode-like problems locally. Currently, it only supports the C++ language, but it can be extended to support other languages.
options:
-h, --help show this help message and exit
--language {cpp}, -l {cpp}
The programming language.
--list-problems List problems.
--list-testcases List testcases for a problem specified with '--problem' option.
--problem problem_name, -p problem_name
Name of the problem to build and test. Default: TwoSum. Use --list-problems to list all problems.
--problem_builds_dir dir, -d dir
Specifies the directory with the problems. Typically, this is './problem_builds'. If not provided, the script defaults to './problem_builds' in the same directory as the executable.
--run-expected-tests, -r
Run the expected solution. Default: False.
--testcase testcase_name, -t testcase_name
Name of the testcase to run. '--testcase All' will run all testcases. Default: All.
--verbose, -v Print verbose output
Curently only C++ is supported but the framework is setup such that other languages can be added.
This project requires the following to run:
- Python
- CMake 3.12
- Git
- npm
Feel free to contribute with code, test cases, or even code reviews.
For a more in-depth guide on how to contribute and information about the inner workings of OpenLeetCode, please refer to the Docs. You can also join our Discord chat if you have any questions about the usage or development.