👋 Welcome to my LeetCode Toolkit! This repository is a curated collection of my experiences and learnings in the realm of algorithmic challenges. Dive into a variety of solutions and tools, Here are some key highlights:
📈 Graph Algorithms in C++ | 🔍 C Programming Examples | 🐍 Python Solutions Downloader Script |
---|---|---|
Explore graph theory with implementations of algorithms like BFS, DFS, Dijkstra's, Bellman-Ford, and Floyd-Warshall. Includes a tree visualizer for custom input and visualization. |
Features a Magic Square Checker and a Hash-Table implementation. 🎓 For more examples of C coding techniques, take a look at these mini-repositories: 📜Cbits, and 👾TextAnalysisC. |
Enhance your LeetCode experience with a Python script for downloading accepted solutions. Check out the LeetCode Downloader for efficient solution archiving. |
📚 While I've been actively engaged on LeetCode, I've stopped uploading new solutions to this repository. For the most current view of my work, techniques, and progress, please visit my LeetCode profile: Dor-sketch.
- 🔄 Automated login and seamless navigation of LeetCode submissions.
- 📁 Well-organized directory structure for downloaded solutions.
- 📊 A comprehensive, up-to-date list of problems and solutions for quick referencing.
- Install Selenium WebDriver and Python 3.x.
- Clone the repository to your local machine.
- Configure the script with your LeetCode credentials.
- Execute the script to commence the automatic download of solutions.
Leveraging Selenium WebDriver, the script automates both the login process and the navigation on the LeetCode website. It meticulously parses submission history, and identifies accepted solutions, which are then downloaded and saved locally. The script also updates a comprehensive list of problems and solutions for quick reference.
The submission history is parsed from the LeetCode website, and accepted solutions are downloaded and saved locally.
Suggestions and contributions to enhance this downloader are welcome! Please feel free to fork the repository, make improvements, and submit a pull request.
Graph algorithms are a cornerstone of computer science, which I've delved into and implemented in this repository. These algorithms play a pivotal role in tackling complex problems across various network structures like social networks 🌍, computer networks 💻, and biological networks 🧬. Below is a succinct overview of some key graph algorithms and their real-world applications, demonstrated in Graph.cpp:
-
Depth-First Search (DFS) 🌳: This algorithm performs a deep traversal of a graph, exploring as far down each branch as possible before backtracking. It's instrumental in solving puzzles, analyzing networks, and in game playing algorithms.
-
Breadth-First Search (BFS) 🌊: This algorithm broadly traverses a graph, visiting all neighbors at the current depth level before moving to nodes at the next depth level. Widely used in shortest path algorithms and social networking applications for finding connections within a certain number of steps.
-
Dijkstra's Algorithm 🛣️: A renowned algorithm for finding the shortest path between nodes in a weighted graph. Essential in GPS systems for determining the shortest driving routes.
-
Bellman-Ford Algorithm 🔍: Computes shortest paths from a single source vertex to all other vertices in a weighted graph, even handling negative weight edges.
-
Floyd-Warshall Algorithm 🔗: A dynamic programming approach for finding shortest paths in a weighted graph with positive or negative edge weights, without negative cycles.
These algorithms are implemented in my repository, showcasing my grasp of graph theory and its practical applications in solving real-world problems.
- Clone the repository to your local machine.
- Navigate to the C++_GraphAlgorithms directory.
- Use the
make
command to compile the program. - Execute the program to run the algorithms with
./GraphApp
.
-
Add your graph in a
.txt
file and see the results:Test 1 passed. 0 ├── 1 └── 2 Test 2 passed. 0 ├── 1 ├── 2 ├── 3 └── 4 Test 3 passed. 0 ├── 1 | ├── 3 | └── 4 └── 2 ├── 5 └── 6 Test 4 passed. 0 └── 1 └── 2 └── 3
BFS Algorithms tests example
You can find a comprehensive list of problems and solutions in problems.md.
New solutions are added regularly via the LeetCode Downloader. Old solutions are available in the Hard, Medium, and Easy directories like so:
.
├── Easy/
│ ├── Arrays/
│ ├── Strings/
│ └── ...
├── Medium/
│ ├── LinkedList/
│ ├── Trees/
│ └── ...
└── Hard/
├── Graphs/
├── Dynamic Programming/
└── ...
Although this is a personal repository primarily for self-learning, feedback or improvement suggestions are welcome. Please open an issue or submit a pull request.
This project is open source and available under the MIT License.