Search⌘ K
AI Features

Solution: Erect the Fence

Explore how to enclose a set of points representing trees with the shortest possible fence by computing their convex hull. Understand the Monotone Chain algorithm, orientation checks with cross products, and how to build lower and upper hulls to form the fence perimeter.

Statement

You are given an array of points, trees, where trees[i] = [xᵢ, yᵢ] represents the location of a tree on a 2D plane. Your goal is to enclose all the trees using the shortest possible length of rope, forming a fence around the garden. A garden is considered well-fenced if every tree lies inside or on the boundary of the fence (i.e., the fence forms the convex hullThis is the smallest convex shape, completely encloses a set of points. of all the points).

Return the coordinates of the trees that lie exactly on the fence perimeter. You can return the answer in any order.

Constraints:

  • 11 \leq trees.length 300\leq 300

  • trees[i].length == 22

  • 00 \leq xi, yi 100\leq ...