1501. 可以放心投资的国家

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/countries-you-can-safely-invest-in
表 Person:

±---------------±--------+
| Column Name | Type |
±---------------±--------+
| id | int |
| name | varchar |
| phone_number | varchar |
±---------------±--------+
id 是该表主键.
该表每一行包含一个人的名字和电话号码.
电话号码的格式是:‘xxx-yyyyyyy’, 其中xxx是国家码(3个字符), yyyyyyy是电话号码(7个字符), x和y都表示数字. 同时, 国家码和电话号码都可以包含前导0.
表 Country:

±---------------±--------+
| Column Name | Type |
±---------------±--------+
| name | varchar |
| country_code | varchar |
±---------------±--------+
country_code是该表主键.
该表每一行包含国家名和国家码. country_code的格式是’xxx’, x是数字.

表 Calls:

±------------±-----+
| Column Name | Type |
±------------±-----+
| caller_id | int |
| callee_id | int |
| duration | int |
±------------±-----+
该表无主键, 可能包含重复行.
每一行包含呼叫方id, 被呼叫方id和以分钟为单位的通话时长. caller_id != callee_id
一家电信公司想要投资新的国家. 该公司想要投资的国家是: 该国的平均通话时长要严格地大于全球平均通话时长.

写一段 SQL, 找到所有该公司可以投资的国家.

返回的结果表没有顺序要求.

查询的结果格式如下例所示.

Person 表:
±—±---------±-------------+
| id | name | phone_number |
±—±---------±-------------+
| 3 | Jonathan | 051-1234567 |
| 12 | Elvis | 051-7654321 |
| 1 | Moncef | 212-1234567 |
| 2 | Maroua | 212-6523651 |
| 7 | Meir | 972-1234567 |
| 9 | Rachel | 972-0011100 |
±—±---------±-------------+

Country 表:
±---------±-------------+
| name | country_code |
±---------±-------------+
| Peru | 051 |
| Israel | 972 |
| Morocco | 212 |
| Germany | 049 |
| Ethiopia | 251 |
±---------±-------------+

Calls 表:
±----------±----------±---------+
| caller_id | callee_id | duration |
±----------±----------±---------+
| 1 | 9 | 33 |
| 2 | 9 | 4 |
| 1 | 2 | 59 |
| 3 | 12 | 102 |
| 3 | 12 | 330 |
| 12 | 3 | 5 |
| 7 | 9 | 13 |
| 7 | 1 | 3 |
| 9 | 7 | 1 |
| 1 | 7 | 7 |
±----------±----------±---------+

Result 表:
±---------+
| country |
±---------+
| Peru |
±---------+
国家Peru的平均通话时长是 (102 + 102 + 330 + 330 + 5 + 5) / 6 = 145.666667
国家Israel的平均通话时长是 (33 + 4 + 13 + 13 + 3 + 1 + 1 + 7) / 8 = 9.37500
国家Morocco的平均通话时长是 (33 + 4 + 59 + 59 + 3 + 7) / 6 = 27.5000
全球平均通话时长 = (2 * (33 + 4 + 59 + 102 + 330 + 5 + 13 + 3 + 1 + 7)) / 20 = 55.70000
所以, Peru是唯一的平均通话时长大于全球平均通话时长的国家, 也是唯一的推荐投资的国家.

此题收获
先分析一下这个题 需要什么 求的是国家的通话时长大于全球平均的通话时长
第一步先求出全球平均时长 很简单用一下avg函数就行
SELECT AVG(duration) from Calls
第二步怎么求国家的平均时长呢
(1) 所以先吧Person LEFT JOIN Country把id和countryName对应起来

Person p LEFT join Country c1 on 
# left 就是从左开始取3个数字正好对应Country 中的字段
LEFT(p.phone_number,3) 
= c1.country_code

(2)通过UNION把Calls表两人通话时长记录转化成每个人的通话时长记录表 c2

SELECT caller_id id,duration from Calls 
   UNION 
SELECT callee_id id ,duration from Calls 

(3) 前两个步骤做完之间链接起来就能求出平均值

SELECT c1.name country  
from Person p 
LEFT join Country c1 
on LEFT(p.phone_number,3) = c1.country_code
join 
(
    SELECT caller_id id,duration from Calls 
    UNION 
    SELECT callee_id id ,duration from Calls 
)
c2 on c2.id=p.id
GROUP by c1.name 
HAVING AVG(duration) > (SELECT AVG(duration) from Calls)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Nicholas_giao

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值