From 2b804b28500458eb363d4648aaffb3c2620e3024 Mon Sep 17 00:00:00 2001 From: Bhupendrakumar20 Date: Sun, 3 Nov 2024 23:19:38 +0530 Subject: [PATCH] add sweep line algo --- StackQueues/Sweep Line Algorithm/Program.c | 59 +++++++++++++++ StackQueues/Sweep Line Algorithm/Readme.md | 85 ++++++++++++++++++++++ 2 files changed, 144 insertions(+) create mode 100644 StackQueues/Sweep Line Algorithm/Program.c create mode 100644 StackQueues/Sweep Line Algorithm/Readme.md diff --git a/StackQueues/Sweep Line Algorithm/Program.c b/StackQueues/Sweep Line Algorithm/Program.c new file mode 100644 index 00000000..a2cbea20 --- /dev/null +++ b/StackQueues/Sweep Line Algorithm/Program.c @@ -0,0 +1,59 @@ +#include +#include + +typedef struct Point { + int x, y; +} Point; + +// Comparison function for qsort() to sort points by x, then y coordinates +int compare(const void *a, const void *b) { + Point *p1 = (Point *)a; + Point *p2 = (Point *)b; + if (p1->x != p2->x) + return p1->x - p2->x; + return p1->y - p2->y; +} + +// Cross product of vectors OA and OB. A positive cross product indicates a left turn +int cross_product(Point O, Point A, Point B) { + return (A.x - O.x) * (B.y - O.y) - (A.y - O.y) * (B.x - O.x); +} + +// Function to compute the convex hull using Sweep Line Algorithm +void convex_hull(Point *points, int n, Point *hull, int *hull_size) { + qsort(points, n, sizeof(Point), compare); + + int i, k = 0; + + // Build the lower hull + for (i = 0; i < n; i++) { + while (k >= 2 && cross_product(hull[k - 2], hull[k - 1], points[i]) <= 0) k--; + hull[k++] = points[i]; + } + + // Build the upper hull + int t = k + 1; + for (i = n - 2; i >= 0; i--) { + while (k >= t && cross_product(hull[k - 2], hull[k - 1], points[i]) <= 0) k--; + hull[k++] = points[i]; + } + + *hull_size = k - 1; // The last point is the same as the first point, so exclude it +} + +int main() { + Point points[] = {{0, 3}, {2, 2}, {1, 1}, {2, 1}, {3, 0}, {0, 0}, {3, 3}}; + int n = sizeof(points) / sizeof(points[0]); + + Point hull[2 * n]; + int hull_size; + + convex_hull(points, n, hull, &hull_size); + + printf("Convex Hull:\n"); + for (int i = 0; i < hull_size; i++) { + printf("(%d, %d)\n", hull[i].x, hull[i].y); + } + + return 0; +} diff --git a/StackQueues/Sweep Line Algorithm/Readme.md b/StackQueues/Sweep Line Algorithm/Readme.md new file mode 100644 index 00000000..a3bd6467 --- /dev/null +++ b/StackQueues/Sweep Line Algorithm/Readme.md @@ -0,0 +1,85 @@ +# Convex Hull Implementation Using Sweep Line Algorithm + +## Description + +The **convex hull** of a set of 2D points is the smallest convex boundary that can enclose all given points. This C program computes the convex hull using **Sweep Line Algorithm**, which is an efficient method with \(O(n \log n)\) complexity, where \(n\) is the number of input points. The algorithm relies on sorting points and then constructing the hull by checking for convexity using the cross product. + +In this implementation: + +- **Sorting** arranges the points by their x-coordinates, and by y-coordinates for points with the same x-coordinate. +- **Cross Product** helps in determining the orientation of three points to ensure convexity. +- **Lower and Upper Hull Construction** builds the convex hull boundary in two stages, covering the points from left to right and from right to left. + +## Problem Definition + +The goal is to compute the convex hull of a set of 2D points using a **sweep line** approach in conjunction with the monotone chain technique. This implementation performs the following operations: + +1. **Sort** the points by x and y coordinates. +2. **Build the Lower Hull**: Iterate from left to right, adding points to the lower hull. +3. **Build the Upper Hull**: Iterate from right to left, adding points to the upper hull. +4. **Check Convexity**: Use the cross product to verify if the new point maintains the convex shape. If not, backtrack by removing the last point from the hull. + +### Key Operations: + +- **Sorting**: Orders points to simplify the convex hull construction process. +- **Cross Product**: Determines if three points make a left or right turn, ensuring the hull remains convex. +- **Lower and Upper Hull Construction**: Ensures all points on the convex boundary are included. + +## Algorithm Review + +### 1. Sorting: +- Sort the points by x-coordinate, and by y-coordinate if x values are the same. +- This ordering enables a structured left-to-right and right-to-left traversal. + +### 2. Building the Lower Hull: +- For each point in the sorted list, check if adding it maintains convexity by using the cross product. +- If adding a point creates a "right turn" (or a concave angle), backtrack by removing the last added point. + +### 3. Building the Upper Hull: +- Repeat the process for the sorted list in reverse to form the upper half of the hull. + +### 4. Cross Product: +- The cross product of vectors \( \overrightarrow{OA} \) and \( \overrightarrow{OB} \) tells us if points O, A, and B make a left turn (positive), a right turn (negative), or are collinear (zero). +- Only points creating left turns are included in the hull. + +## Time Complexity + +- **Sorting**: \(O(n \log n)\) +- **Convex Hull Construction**: \(O(n)\), as each point is added and removed at most once. +- **Overall Complexity**: \(O(n \log n)\) + +## Example + +Given the input points: + +```plaintext +{ (0, 3), (2, 2), (1, 1), (2, 1), (3, 0), (0, 0), (3, 3) } +``` + +The output convex hull will be: + +```plaintext +(0, 0) +(3, 0) +(3, 3) +(0, 3) +``` + +These points represent the convex boundary around the given set of points in counter-clockwise order. +## Explanation of the Code + +1. **Struct Definition**: A `Point` structure is defined to store `x` and `y` coordinates. + +2. **Sorting Function**: + - `compare` sorts the points by x, and then by y if x-coordinates are the same. + +3. **Cross Product Function**: + - The `cross_product` function checks the orientation of three points, returning a positive value for a left turn. + +4. **Convex Hull Construction**: + - The `convex_hull` function first sorts the points and then builds the lower and upper hulls. + - The result is stored in the `hull` array, with `hull_size` representing the number of vertices in the hull. + +5. **Main Function**: + - Initializes points and calls `convex_hull` to compute and print the convex hull vertices. +