Problem 194. Clockwise or Counterclockwise
Given a list of 2-d points defining the vertices of a polygon, determine whether these points are sorted clockwise.
The inputs to this function are two vectors x and y (with equal size) containing the x- and y- coordinates of the polygon vertices, respectively.
The function should return true when sorted clockwise, and false when sorted counterclockwise (the polygon vertices will always be sorted either way).
Example:
x = [-1,-1,1,1]; y = [-1,1,1,-1];
defines a square, the vertices are listed clockwise
d_correct = true;
Solution Stats
Problem Comments
- 
		3 Comments
added more samples to the test
Hello, Alfonso Nieto-Castanon.  This is a very nice problem.  It was interesting to see the variety of approaches used to solve it.  It was also interesting to notice a few submissions failed your added test cases from circa Dec 2017.  Do you allow for self-intersecting polygons, as per https://en.wikipedia.org/wiki/Polygon ?
I suspect a common solution tactic will fail badly when faced with self-intersecting polygons.  —DIV
...On second thought, maybe there's no consistent definition of CW/CCW for self-intersecting polygons, such as figure-eight or bow-tie ("cross-quadrilateral") shapes.
Solution Comments
Show commentsProblem Recent Solvers209
Suggested Problems
- 
         Return the largest number that is adjacent to a zero 5453 Solvers 
- 
         
         2194 Solvers 
- 
         How to find the position of an element in a vector without using the find function 2774 Solvers 
- 
         Back to basics 21 - Matrix replicating 1749 Solvers 
- 
         Write c^3 as sum of two squares a^2+b^2 321 Solvers 
More from this Author38
Problem Tags
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!