leetcode612. 平面上的最近距离(SQL)

表 point_2d 保存了所有点(多于 2 个点)的坐标 (x,y) ,这些点在平面上两两不重合。

写一个查询语句找到两点之间的最近距离,保留 2 位小数。

| x  | y  |
|----|----|
| -1 | -1 |
| 0  | 0  |
| -1 | -2 |
 

最近距离在点 (-1,-1) 和(-1,2) 之间,距离为 1.00 。所以输出应该为:

| shortest |
|----------|
| 1.00     |
 

注意:任意点之间的最远距离小于 10000 。

思路:写出来求距离的公式,保存两位小数,求最小即可。

SELECT MIN(ROUND( SQRT(  (POW(p1.x - p2.x, 2) + POW(p1.y - p2.y, 2) ) ), 2) ) AS shortest
FROM point_2d as p1,point_2d as p2
where p1.x > p2.x OR p1.y > p2.y;
扫描二维码关注公众号,回复: 9266629 查看本文章
发布了589 篇原创文章 · 获赞 1万+ · 访问量 139万+

猜你喜欢

转载自blog.csdn.net/hebtu666/article/details/104396629