diff --git a/Arrays/Anagram_Check_manual_Sol.py b/Arrays/AnagramCheckManualSol.py similarity index 100% rename from Arrays/Anagram_Check_manual_Sol.py rename to Arrays/AnagramCheckManualSol.py diff --git a/Arrays/Anagram_Check_Sorted_Sol.py b/Arrays/AnagramCheckSortedSol.py similarity index 100% rename from Arrays/Anagram_Check_Sorted_Sol.py rename to Arrays/AnagramCheckSortedSol.py diff --git a/Arrays/ArrayFindTheMissingElement_brute_force_sol.py b/Arrays/ArrayFindTheMissingElementBruteForceSol.py similarity index 100% rename from Arrays/ArrayFindTheMissingElement_brute_force_sol.py rename to Arrays/ArrayFindTheMissingElementBruteForceSol.py diff --git a/Arrays/ArrayFindTheMissingElement_hash_table_sol.py b/Arrays/ArrayFindTheMissingElementHashTableSol.py similarity index 100% rename from Arrays/ArrayFindTheMissingElement_hash_table_sol.py rename to Arrays/ArrayFindTheMissingElementHashTableSol.py diff --git a/Arrays/ArrayFindTheMissingElement_takingSumandSubtract_sol.py b/Arrays/ArrayFindTheMissingElementSumSol.py similarity index 100% rename from Arrays/ArrayFindTheMissingElement_takingSumandSubtract_sol.py rename to Arrays/ArrayFindTheMissingElementSumSol.py diff --git a/Arrays/ArrayFindTheMissingElement_XOR_sol.py b/Arrays/ArrayFindTheMissingElementXORSol.py similarity index 100% rename from Arrays/ArrayFindTheMissingElement_XOR_sol.py rename to Arrays/ArrayFindTheMissingElementXORSol.py diff --git a/Arrays/README.md b/Arrays/README.md index 707a82e..3d4e863 100644 --- a/Arrays/README.md +++ b/Arrays/README.md @@ -4,10 +4,10 @@ This directory contains Python implementations of common array-based algorithms ## Contents -- [Anagram Check (Sorted Solution)](Anagram_Check_Sorted_Sol.py): Checks if two strings are anagrams by comparing their sorted versions. -- [Anagram Check (Manual Solution)](Anagram_Check_manual_Sol.py): Checks if two strings are anagrams using a hash table (dictionary) to count character frequencies. -- [Array Find Missing Element (XOR Solution)](ArrayFindTheMissingElement_XOR_sol.py): Efficiently finds a missing element in a shuffled array using bitwise XOR. -- [Array Find Missing Element (Brute Force Solution)](ArrayFindTheMissingElement_brute_force_sol.py): Finds a missing element by sorting both arrays and comparing them. -- [Array Find Missing Element (Hash Table Solution)](ArrayFindTheMissingElement_hash_table_sol.py): Finds a missing element using a hash table (dictionary) to track element counts. -- [Array Find Missing Element (Sum/Subtract Solution)](ArrayFindTheMissingElement_takingSumandSubtract_sol.py): Finds a missing element by calculating the difference between the sums of the two arrays. -- [Array Pair Sum Solution](ArrayPairSumSol.py): Finds all unique pairs in an array that sum up to a specific value $k$ using a set for $O(n)$ complexity. +- [Anagram Check (Sorted Solution)](AnagramCheckSortedSol.py): Checks if two strings are anagrams by comparing their sorted versions. Time Complexity: $O(n \log n)$ +- [Anagram Check (Manual Solution)](AnagramCheckManualSol.py): Checks if two strings are anagrams using a hash table (dictionary) to count character frequencies. Time Complexity: $O(n)$ +- [Array Find Missing Element (XOR Solution)](ArrayFindTheMissingElementXORSol.py): Efficiently finds a missing element in a shuffled array using bitwise XOR. Time Complexity: $O(n)$ +- [Array Find Missing Element (Brute Force Solution)](ArrayFindTheMissingElementBruteForceSol.py): Finds a missing element by sorting both arrays and comparing them. Time Complexity: $O(n \log n)$ +- [Array Find Missing Element (Hash Table Solution)](ArrayFindTheMissingElementHashTableSol.py): Finds a missing element using a hash table (dictionary) to track element counts. Time Complexity: $O(n)$ +- [Array Find Missing Element (Sum/Subtract Solution)](ArrayFindTheMissingElementSumSol.py): Finds a missing element by calculating the difference between the sums of the two arrays. Time Complexity: $O(n)$ +- [Array Pair Sum Solution](ArrayPairSumSol.py): Finds all unique pairs in an array that sum up to a specific value $k$ using a set for $O(n)$ complexity. Time Complexity: $O(n)$ diff --git a/deque/DequeImple.py b/Deque/DequeImple.py similarity index 100% rename from deque/DequeImple.py rename to Deque/DequeImple.py diff --git a/deque/README.md b/Deque/README.md similarity index 73% rename from deque/README.md rename to Deque/README.md index 046a17f..bb6e4e4 100644 --- a/deque/README.md +++ b/Deque/README.md @@ -4,4 +4,4 @@ This directory contains Python implementations of the Deque (Double-Ended Queue) ## Contents -- [Deque Implementation](DequeImple.py): Basic implementation of a Deque using a Python list. Includes operations like `addFront`, `addRear`, `removeFront`, `removeRear`, `isEmpty`, and `size`. +- [Deque Implementation](DequeImple.py): Basic implementation of a Deque using a Python list. Includes operations like `addFront`, `addRear`, `removeFront`, `removeRear`, `isEmpty`, and `size`. Time Complexity: $O(1)$ for `addFront`/`removeFront`, $O(n)$ for `addRear`/`removeRear` (due to list shifting). diff --git a/Error-debug/README.md b/Error-debug/README.md deleted file mode 100644 index c8bc4d4..0000000 --- a/Error-debug/README.md +++ /dev/null @@ -1,7 +0,0 @@ -# Error and Debugging - -This directory contains examples of error handling and debugging techniques in Python. - -## Contents - -- [Error and Exceptions](ErrorExceptions.py): Demonstrates the use of `try`, `except`, `else`, and `finally` blocks for robust error handling, specifically validating integer user input. diff --git a/Error-debug/ErrorExceptions.py b/ErrorHandling/ErrorExceptions.py similarity index 100% rename from Error-debug/ErrorExceptions.py rename to ErrorHandling/ErrorExceptions.py diff --git a/ErrorHandling/README.md b/ErrorHandling/README.md new file mode 100644 index 0000000..fc91dd5 --- /dev/null +++ b/ErrorHandling/README.md @@ -0,0 +1,7 @@ +# Error Handling & Debugging + +This directory contains examples of error handling and debugging in Python. + +## Contents + +- [Error and Exceptions](ErrorExceptions.py): Demonstrates `try`, `except`, `else`, and `finally` blocks for robust error handling. diff --git a/GraphAlgorithms/README.md b/GraphAlgorithms/README.md index f0330f8..0084b7d 100644 --- a/GraphAlgorithms/README.md +++ b/GraphAlgorithms/README.md @@ -4,9 +4,9 @@ This directory contains Python implementations of common graph-based algorithms ## Contents -- [Adjacency List Implementation](AdjacencyListGraphImple.py): Implements the Graph Abstract Data Type (ADT) using an adjacency list (dictionaries in Python). Includes `Vertex` and `Graph` classes. -- [Breadth First Search (BFS)](BFS.py): Implements BFS to solve the Word Ladder problem, finding the shortest transformation path between words. -- [General Depth First Search (DFS)](DFSGeneral.py): Provides a general implementation of DFS, including discovery and finish times for vertices. -- [DFS - Knight's Tour Problem](DFSImpleTheKnightsTourProblem.py): Another implementation of DFS specifically tailored to the Knight's Tour puzzle. -- [The Knight's Tour Problem](TheKnightsTourProblem.py): Focuses on generating the knight's move graph and solving the tour using DFS and backtracking. -- [Word Ladder Problem](WordLadderProblem.py): Specifically focuses on building the word ladder graph where edges connect words that differ by only one letter. +- [Adjacency List Implementation](AdjacencyListGraphImple.py): Implements the Graph Abstract Data Type (ADT) using an adjacency list (dictionaries in Python). Includes `Vertex` and `Graph` classes. Time Complexity: $O(1)$ for adding vertices/edges. +- [Breadth First Search (BFS)](BFS.py): Implements BFS to solve the Word Ladder problem. Time Complexity: $O(V+E)$. +- [General Depth First Search (DFS)](DFSGeneral.py): Provides a general implementation of DFS. Time Complexity: $O(V+E)$. +- [DFS - Knight's Tour Problem](DFSImpleTheKnightsTourProblem.py): Implementation of DFS specifically tailored to the Knight's Tour puzzle. Time Complexity: $O(k^N)$. +- [The Knight's Tour Problem](TheKnightsTourProblem.py): Focuses on generating the knight's move graph. Time Complexity: $O(k^N)$. +- [Word Ladder Problem](WordLadderProblem.py): Focuses on building the word ladder graph. Time Complexity: $O(n \cdot m^2)$ where $n$ is number of words and $m$ is word length. diff --git a/LinkedLists/README.md b/LinkedLists/README.md index bead21d..d69dc71 100644 --- a/LinkedLists/README.md +++ b/LinkedLists/README.md @@ -1,11 +1,11 @@ # Linked Lists -This directory contains Python implementations of various types of linked lists and related algorithms. +This directory contains Python implementations of Singly and Doubly Linked Lists and related problems. ## Contents -- [Singly Linked List Implementation](SingleLinkedListImple.py): Basic implementation of a singly linked list node and basic linkage. -- [Doubly Linked List Implementation](DoublyLinkedListImple.py): Basic implementation of a doubly linked list node with `prev` and `next` pointers. -- [Singly Linked List Cycle Check](SinglyLinkedListCycleCheckImple.py): Implements Floyd's Cycle-Finding Algorithm (two pointers) to detect cycles in a linked list. -- [Linked List Reversal](LinkedListReversal.py): Reverses a singly linked list in-place in $O(n)$ time. -- [Nth to Last Node](LinkedListNthToLastNode.py): Finds the $n$-th to last node in a singly linked list using two pointers. +- [Singly Linked List Implementation](SingleLinkedListImple.py): Basic Singly Linked List with `next` pointer. Time Complexity: $O(1)$ for insertion at head. +- [Doubly Linked List Implementation](DoublyLinkedListImple.py): Basic Doubly Linked List with `next` and `prev` pointers. Time Complexity: $O(1)$ for insertion. +- [Cycle Detection](SinglyLinkedListCycleCheckImple.py): Detects if a linked list has a cycle using Floyd's Cycle-Finding Algorithm (Tortoise and Hare). Time Complexity: $O(n)$. +- [Linked List Reversal](LinkedListReversal.py): In-place reversal of a Singly Linked List. Time Complexity: $O(n)$. +- [N-th to Last Node](LinkedListNthToLastNode.py): Finds the $n$-th node from the end of a Singly Linked List. Time Complexity: $O(n)$. diff --git a/Queues/README.md b/Queues/README.md index a1c90d0..d93af57 100644 --- a/Queues/README.md +++ b/Queues/README.md @@ -4,5 +4,5 @@ This directory contains Python implementations of the Queue data structure. ## Contents -- [Queue Implementation](QueueImple.py): Basic implementation of a FIFO (First-In-First-Out) queue using a Python list. Includes `enqueue`, `dequeue`, `isEmpty`, and `size` methods. -- [Queue with Two Stacks](QueueWith2StacksImple.py): Implements a queue using two stacks (represented by Python lists) to achieve FIFO behavior. +- [Queue Implementation](QueueImple.py): Basic implementation of a FIFO (First-In-First-Out) queue using a Python list. Time Complexity: $O(n)$ for `enqueue` (due to `insert(0)`), $O(1)$ for `dequeue`. +- [Queue with Two Stacks](QueueWith2StacksImple.py): Implements a queue using two stacks to achieve FIFO behavior. Time Complexity: Amortized $O(1)$ for both operations. diff --git a/README.md b/README.md index b8de7d5..126435e 100644 --- a/README.md +++ b/README.md @@ -35,23 +35,23 @@ See [CONTRIBUTING.md](CONTRIBUTING.md) for more details. ## 📖 Table of Contents -- [Getting Started](#getting-started) -- [Project Structure](#project-structure) -- [Data Structures](#data-structures) - - [Arrays](#arrays) - - [Linked Lists](#linked-lists) - - [Stacks](#stacks) - - [Queues](#queues) - - [Deque](#deque) - - [Trees](#trees) -- [Algorithms](#algorithms) - - [Sorting](#sorting) - - [Recursion & Dynamic Programming](#recursion--dynamic-programming) - - [Graph Algorithms](#graph-algorithms) -- [Error Handling & Debugging](#error-handling--debugging) -- [Usage](#usage) -- [Quick Reference](#quick-reference) -- [License](#license) +- [Getting Started](#-getting-started) +- [Project Structure](#-project-structure) +- [Data Structures](#-data-structures) + - [Arrays 🔤](#arrays-) + - [Linked Lists 🔗](#linked-lists-) + - [Stacks 📚](#stacks-) + - [Queues 📦](#queues-) + - [Deque 🔄](#deque-) + - [Trees 🌳](#trees-) +- [Algorithms](#-algorithms) + - [Sorting 📊](#sorting-) + - [Recursion & Dynamic Programming 🔀](#recursion--dynamic-programming-) + - [Graph Algorithms 🗺️](#graph-algorithms-) +- [Error Handling & Debugging](#-error-handling--debugging) +- [Usage](#-usage) +- [Quick Reference](#-quick-reference) +- [License](#-license) --- @@ -67,7 +67,7 @@ Most scripts in this repository are standalone and can be executed directly: ```bash # Run any Python script -python3 Arrays/Anagram_Check_Sorted_Sol.py +python3 Arrays/AnagramCheckSortedSol.py # Or run from the repo root python3 Sorting/BubbleSortImple.py @@ -80,7 +80,8 @@ python3 Sorting/BubbleSortImple.py ``` . ├── Arrays/ # 🔤 Array-based problems and algorithms -├── Error-debug/ # ⚠️ Error handling and debugging examples +├── Deque/ # 🔄 Double-ended queue +├── ErrorHandling/ # ⚠️ Error handling and debugging examples ├── GraphAlgorithms/ # 🗺️ Graph traversal (BFS, DFS) and pathfinding ├── LinkedLists/ # 🔗 Singly and Doubly Linked Lists ├── Queues/ # 📦 Queue implementations (FIFO) @@ -88,7 +89,6 @@ python3 Sorting/BubbleSortImple.py ├── Sorting/ # 📊 Common sorting algorithms ├── Stacks/ # 📚 Stack implementations and applications ├── Trees/ # 🌳 Binary Trees, BSTs, Heaps, and Traversals -├── deque/ # 🔄 Double-ended queue ├── CONTRIBUTING.md # 🤝 Contribution guidelines ├── LICENSE # 📄 MIT License └── README.md # 📖 This file @@ -100,9 +100,9 @@ python3 Sorting/BubbleSortImple.py ### Arrays 🔤 Common array-based algorithms and manipulations. -- [Anagram Check](Arrays/): [Sorted](Arrays/Anagram_Check_Sorted_Sol.py) & [Manual](Arrays/Anagram_Check_manual_Sol.py) solutions +- [Anagram Check](Arrays/): [Sorted](Arrays/AnagramCheckSortedSol.py) & [Manual](Arrays/AnagramCheckManualSol.py) solutions - [Array Pair Sum](Arrays/ArrayPairSumSol.py): Find pairs that sum to $k$ -- [Find Missing Element](Arrays/): [XOR](Arrays/ArrayFindTheMissingElement_XOR_sol.py), [Brute Force](Arrays/ArrayFindTheMissingElement_brute_force_sol.py), [Hash Table](Arrays/ArrayFindTheMissingElement_hash_table_sol.py), & [Sum](Arrays/ArrayFindTheMissingElement_takingSumandSubtract_sol.py) approaches +- [Find Missing Element](Arrays/): [XOR](Arrays/ArrayFindTheMissingElementXORSol.py), [Brute Force](Arrays/ArrayFindTheMissingElementBruteForceSol.py), [Hash Table](Arrays/ArrayFindTheMissingElementHashTableSol.py), & [Sum](Arrays/ArrayFindTheMissingElementSumSol.py) approaches ### Linked Lists 🔗 Implementations and problems involving linked structures. @@ -123,7 +123,7 @@ FIFO (First-In-First-Out) data structures. ### Deque 🔄 Double-ended queue operations. -- [Deque Implementation](deque/DequeImple.py): Operations at both ends +- [Deque Implementation](Deque/DequeImple.py): Operations at both ends ### Trees 🌳 Hierarchical data structures. @@ -133,7 +133,7 @@ Hierarchical data structures. - [Binary Heap](Trees/BinaryHeapImple.py): Min-heap implementation - [Tree Traversals](Trees/TreeLevelOrderPrintImple.py): Level order (BFS) printing - [Trim BST](Trees/TrimBinarySearchTreeImple.py): Keep nodes within a range -- [Tree Representations](Trees/): [Nodes & References](Trees/TreeRepresentationWithNodesReferences.py) & [List of Lists](Trees/buildTreeTest.py) +- [Tree Representations](Trees/): [Nodes & References](Trees/TreeRepresentationWithNodesReferences.py) & [List of Lists](Trees/BuildTreeTest.py) --- @@ -144,7 +144,7 @@ Algorithms for arranging elements in order. - [Bubble Sort](Sorting/BubbleSortImple.py) - $O(n^2)$ - [Selection Sort](Sorting/SelectionSortImple.py) - $O(n^2)$ - [Insertion Sort](Sorting/InsertionSortImple.py) - $O(n^2)$ -- [Shell Sort](Sorting/ShellSortImple.py) - $O(n \log n)$ +- [Shell Sort](Sorting/ShellSortImple.py) - $O(n^2)$ worst case - [Merge Sort](Sorting/MergeSortImple.py) - $O(n \log n)$ - [Quick Sort](Sorting/QuickSortImple.py) - $O(n \log n)$ average @@ -168,7 +168,7 @@ Algorithms for graph traversal and pathfinding. ## ⚠️ Error Handling & Debugging -- [Error and Exceptions](Error-debug/ErrorExceptions.py): Demonstrates `try`, `except`, `else`, and `finally` blocks for robust error handling. +- [Error and Exceptions](ErrorHandling/ErrorExceptions.py): Demonstrates `try`, `except`, `else`, and `finally` blocks for robust error handling. --- @@ -214,8 +214,8 @@ New to DSA? Follow this recommended order: ## 🔮 Roadmap +- [x] Update complexity analysis for all solutions - [ ] Add more graph algorithms (Dijkstra, Bellman-Ford) -- [ ] Include complexity analysis for each solution - [ ] Add interactive examples/visualizations - [ ] Create a difficulty level classification - [ ] Add more test cases diff --git a/Recursion/README.md b/Recursion/README.md index 7265340..0c68383 100644 --- a/Recursion/README.md +++ b/Recursion/README.md @@ -1,21 +1,16 @@ -# Recursion +# Recursion and Dynamic Programming -This directory contains Python implementations of problems solved using recursion and dynamic programming. +This directory contains examples of recursion and dynamic programming problems. ## Contents -### Fibonacci Sequence -- [Fibonacci (Iterative)](FibonacciSeqIterative.py): Iterative implementation of the Fibonacci sequence. -- [Fibonacci (Recursive)](FibonacciSeqRecursion.py): Simple recursive implementation of the Fibonacci sequence. -- [Fibonacci (Dynamic Programming)](FibonacciSeqDynamic.py): Optimized Fibonacci sequence using memoization. - -### Coin Change Problem -- [Coin Change (Recursive)](CoinChangeProblemRecursion.py): Basic recursive solution to find the minimum number of coins for change. -- [Coin Change (Dynamic Programming)](CoinChangeProblemDynamic.py): Optimized solution to the coin change problem using dynamic programming. - -### Other Recursive Problems -- [Cumulative Sum](RecursionCumulativeSum.py): Computes the cumulative sum from 0 to $n$ recursively. -- [Reverse a String](RecursionReverseStr.py): Reverses a string using recursive calls. -- [String Permutations](RecursionStrPermutation.py): Generates all possible permutations of a given string. -- [Sum of Digits](RecursionSumOfDigits.py): Calculates the sum of all individual digits in an integer recursively. -- [Word Split](RecursionWordSplit.py): Determines if a string can be split into words from a given list. +- [Coin Change Problem (Dynamic Programming)](CoinChangeProblemDynamic.py): Solves the coin change problem using DP. Time Complexity: $O(n \cdot m)$. +- [Coin Change Problem (Recursive)](CoinChangeProblemRecursion.py): Recursive solution to the coin change problem. Time Complexity: Exponential. +- [Fibonacci Sequence (Dynamic Programming)](FibonacciSeqDynamic.py): Fibonacci implementation using memoization/DP. Time Complexity: $O(n)$. +- [Fibonacci Sequence (Iterative)](FibonacciSeqIterative.py): Iterative Fibonacci implementation. Time Complexity: $O(n)$. +- [Fibonacci Sequence (Recursive)](FibonacciSeqRecursion.py): Simple recursive Fibonacci implementation. Time Complexity: $O(2^n)$. +- [Cumulative Sum](RecursionCumulativeSum.py): Recursive implementation of cumulative sum. Time Complexity: $O(n)$. +- [Reverse String](RecursionReverseStr.py): Recursive string reversal. Time Complexity: $O(n)$. +- [String Permutation](RecursionStrPermutation.py): Generates all permutations of a string. Time Complexity: $O(n!)$. +- [Sum of Digits](RecursionSumOfDigits.py): Recursive sum of digits of a number. Time Complexity: $O(\log_{10} n)$. +- [Word Split](RecursionWordSplit.py): Recursive word split problem using DP concepts. Time Complexity: $O(n^2)$. diff --git a/Sorting/README.md b/Sorting/README.md index 0b76399..9502166 100644 --- a/Sorting/README.md +++ b/Sorting/README.md @@ -1,12 +1,12 @@ # Sorting Algorithms -This directory contains Python implementations of various sorting algorithms with explanations of their complexities. +This directory contains Python implementations of various sorting algorithms. ## Contents -- [Bubble Sort](BubbleSortImple.py): Implementation of Bubble Sort with $O(n^2)$ complexity. -- [Selection Sort](SelectionSortImple.py): Implementation of Selection Sort, improving on Bubble Sort by making only one exchange per pass. -- [Insertion Sort](InsertionSortImple.py): Implementation of Insertion Sort, maintaining a sorted sublist. -- [Shell Sort](ShellSortImple.py): Implementation of Shell Sort (diminishing increment sort), improving on Insertion Sort. -- [Merge Sort](MergeSortImple.py): A recursive "divide and conquer" algorithm with $O(n \log n)$ complexity. -- [Quick Sort](QuickSortImple.py): Implementation of Quick Sort (partition exchange sort), using divide and conquer in-place. +- [Bubble Sort](BubbleSortImple.py): Implementation of Bubble Sort. Time Complexity: $O(n^2)$. +- [Selection Sort](SelectionSortImple.py): Implementation of Selection Sort. Time Complexity: $O(n^2)$. +- [Insertion Sort](InsertionSortImple.py): Implementation of Insertion Sort. Time Complexity: $O(n^2)$. +- [Shell Sort](ShellSortImple.py): Implementation of Shell Sort. Time Complexity: $O(n^2)$ worst case. +- [Merge Sort](MergeSortImple.py): Recursive "divide and conquer" algorithm. Time Complexity: $O(n \log n)$. +- [Quick Sort](QuickSortImple.py): Implementation of Quick Sort. Time Complexity: $O(n \log n)$ average, $O(n^2)$ worst case. diff --git a/Stacks/README.md b/Stacks/README.md index e799a74..0fe92f6 100644 --- a/Stacks/README.md +++ b/Stacks/README.md @@ -1,8 +1,8 @@ # Stacks -This directory contains Python implementations of the Stack data structure and its applications. +This directory contains Python implementations of the Stack data structure. ## Contents -- [Stack Implementation](StackImple.py): Basic implementation of a LIFO (Last-In-First-Out) stack using a Python list. Includes `push`, `pop`, `peek`, `isEmpty`, and `size` methods. -- [Balanced Parentheses Check](BalanceParenthlessCheckImple.py): Uses a stack to check if a string of opening and closing parentheses (round, square, and curly) is balanced. +- [Stack Implementation](StackImple.py): Basic LIFO (Last-In-First-Out) stack implementation. Time Complexity: $O(1)$ for all operations. +- [Balanced Parentheses Check](BalanceParenthlessCheckImple.py): Uses a stack to check if a string of parentheses is balanced. Time Complexity: $O(n)$. diff --git a/Trees/buildTreeTest.py b/Trees/BuildTreeTest.py similarity index 100% rename from Trees/buildTreeTest.py rename to Trees/BuildTreeTest.py diff --git a/Trees/README.md b/Trees/README.md index 2047225..03ca814 100644 --- a/Trees/README.md +++ b/Trees/README.md @@ -1,23 +1,16 @@ # Trees -This directory contains Python implementations of various tree-based data structures and algorithms. +This directory contains Python implementations of tree-based data structures and algorithms. ## Contents -### Binary Search Trees (BST) -- [Binary Search Tree Implementation](BinarySearchTreesImple.py): A comprehensive implementation of a BST with `TreeNode` and `BinarySearchTree` classes, including insertion, deletion, and search. -- [Validate BST (Solution 1)](BinarySearchTreeCheckImpleSol1.py): Validates a BST by performing an in-order traversal and checking if the resulting values are sorted. -- [Validate BST (Solution 2)](BinarySearchTreeCheckImpleSol2.py): Validates a BST by keeping track of the minimum and maximum allowable values for each node. -- [Trim a BST](TrimBinarySearchTreeImple.py): Trims a BST so that all node values fall within a specified range $[min, max]$. - -### Search Algorithms -- [Binary Search (Iterative)](BinarySearchImple.py): Iterative implementation of the binary search algorithm on a sorted list. -- [Binary Search (Recursive)](BinarySearchRecursiveImple.py): Recursive implementation of the binary search algorithm. - -### Heaps -- [Binary Heap Implementation](BinaryHeapImple.py): Implements a min-heap using a recursive approach, including `insert`, `delMin`, and `buildHeap`. - -### Tree Representations & Traversals -- [Nodes and References Representation](TreeRepresentationWithNodesReferences.py): A simple implementation of a binary tree using a class-based nodes and references approach. -- [List of Lists Representation](buildTreeTest.py): Demonstrates building and manipulating a tree using a "list of lists" approach. -- [Tree Level Order Print](TreeLevelOrderPrintImple.py): Prints a binary tree in level order (breadth-first) using a queue, with each level on a new line. +- [Binary Search Tree](BinarySearchTreesImple.py): Complete BST implementation with insert, search, and delete. Time Complexity: Average $O(\log n)$, Worst $O(n)$. +- [Binary Search (Iterative)](BinarySearchImple.py): Iterative implementation of binary search. Time Complexity: $O(\log n)$. +- [Binary Search (Recursive)](BinarySearchRecursiveImple.py): Recursive implementation of binary search. Time Complexity: $O(\log n)$. +- [BST Check (Solution 1)](BinarySearchTreeCheckImpleSol1.py): Validates a BST using in-order traversal. Time Complexity: $O(n)$. +- [BST Check (Solution 2)](BinarySearchTreeCheckImpleSol2.py): Validates a BST by checking value ranges. Time Complexity: $O(n)$. +- [Binary Heap](BinaryHeapImple.py): Implementation of a Min-Heap. Time Complexity: $O(\log n)$ for insert/delete. +- [Tree Level Order Print](TreeLevelOrderPrintImple.py): Prints a tree level by level (BFS). Time Complexity: $O(n)$. +- [Trim a BST](TrimBinarySearchTreeImple.py): Trims a BST to a given range. Time Complexity: $O(n)$. +- [Tree Representation (Nodes & References)](TreeRepresentationWithNodesReferences.py): Basic tree representation using classes and pointers. +- [Tree Representation (List of Lists)](BuildTreeTest.py): Tree representation using nested Python lists.