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

举报
兔老大 发表于 2021/04/30 03:35:52 2021/04/30
【摘要】 表 point_2d 保存了所有点(多于 2 个点)的坐标 (x,y) ,这些点在平面上两两不重合。   写一个查询语句找到两点之间的最近距离,保留 2 位小数。   | x  | y  | |----|----| | -1 | -1 | | 0  | 0  | | -1 | -2 | &...

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

 

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

 

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

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

 

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

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

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


  
  1. SELECT MIN(ROUND( SQRT( (POW(p1.x - p2.x, 2) + POW(p1.y - p2.y, 2) ) ), 2) ) AS shortest
  2. FROM point_2d as p1,point_2d as p2
  3. where p1.x > p2.x OR p1.y > p2.y;

 

文章来源: fantianzuo.blog.csdn.net,作者:兔老大RabbitMQ,版权归原作者所有,如需转载,请联系作者。

原文链接:fantianzuo.blog.csdn.net/article/details/104396629

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。