# How to check if given four points form a square

Given coordinates of four points in a plane, find if the four points form a square or not.

To check for square, we need to check for following.

a) All fours sides formed by points are the same.

b) The angle between any two sides is 90 degree. (This condition is required as Quadrilateral also has same sides.

c) Check both the diagonals have the same distance

The idea is to pick any point and calculate its distance from the rest of the points. Let the picked point be ‘p’. To form a square, the distance of two points must be the same from ‘p’, let this distance be d. The distance from one point must be different from that d and must be equal to √2 times d. Let this point with different distance be ‘q’.

The above condition is not good enough as the point with different distance can be on the other side. We also need to check that q is at the same distance from 2 other points and this distance is the same as d.

Below is the C++ implementation of the above idea.

`// A C++ program to check if four given points form a square or not. ` `#include <iostream> ` `using` `namespace` `std; ` ` ` `// Structure of a point in 2D space ` `struct` `Point { ` ` ` `int` `x, y; ` `}; ` ` ` `// A utility function to find square of distance ` `// from point 'p' to point 'q' ` `int` `distSq(Point p, Point q) ` `{ ` ` ` `return` `(p.x - q.x) * (p.x - q.x) + (p.y - q.y) * (p.y - q.y); ` `} ` ` ` `// This function returns true if (p1, p2, p3, p4) form a ` `// square, otherwise false ` `bool` `isSquare(Point p1, Point p2, Point p3, Point p4) ` `{ ` ` ` `int` `d2 = distSq(p1, p2); ` `// from p1 to p2 ` ` ` `int` `d3 = distSq(p1, p3); ` `// from p1 to p3 ` ` ` `int` `d4 = distSq(p1, p4); ` `// from p1 to p4 ` ` ` ` ` `// If lengths if (p1, p2) and (p1, p3) are same, then ` ` ` `// following conditions must met to form a square. ` ` ` `// 1) Square of length of (p1, p4) is same as twice ` ` ` `// the square of (p1, p2) ` ` ` `// 2) Square of length of (p2, p3) is same ` ` ` `// as twice the square of (p2, p4) ` ` ` ` ` `if` `(d2 == d3 && 2 * d2 == d4 ` ` ` `&& 2 * distSq(p2, p4) == distSq(p2, p3)) { ` ` ` `return` `true` `; ` ` ` `} ` ` ` ` ` `// The below two cases are similar to above case ` ` ` `if` `(d3 == d4 && 2 * d3 == d2 ` ` ` `&& 2 * distSq(p3, p2) == distSq(p3, p4)) { ` ` ` `return` `true` `; ` ` ` `} ` ` ` `if` `(d2 == d4 && 2 * d2 == d3 ` ` ` `&& 2 * distSq(p2, p3) == distSq(p2, p4)) { ` ` ` `return` `true` `; ` ` ` `} ` ` ` ` ` `return` `false` `; ` `} ` ` ` `// Driver program to test above function ` `int` `main() ` `{ ` ` ` `Point p1 = { 20, 10 }, p2 = { 10, 20 }, ` ` ` `p3 = { 20, 20 }, p4 = { 10, 10 }; ` ` ` `isSquare(p1, p2, p3, p4) ? cout << ` `"Yes"` `: cout << ` `"No"` `; ` ` ` `return` `0; ` `} ` |

*chevron_right*

*filter_none*

Output:

Yes

**Extended Problem:**

Check if four segments form a rectangle

This article is contributed by **Anuj**. Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above

## Recommended Posts:

- Find Four points such that they form a square whose sides are parallel to x and y axes
- Check if the given 2-D points form T-shape or not
- Check if a number is perfect square without finding square root
- Find Square Root under Modulo p | Set 1 (When p is in form of 4*i + 3)
- Check whether two points (x1, y1) and (x2, y2) lie on same side of a given line or not
- Program to check if three points are collinear
- Check whether four points make a parallelogram
- Check whether it is possible to join two points given on circle such that distance between them is k
- Program to check whether 4 points in a 3-D plane are Coplanar
- Check if two people starting from different points ever meet
- Check if four segments form a rectangle
- Check if given number is perfect square
- Check whether a very large number of the given form is a multiple of 3.
- Check perfect square using addition/subtraction
- Steps required to visit M points in order on a circular ring of N points