返回介绍

solution / 1500-1599 / 1501.Countries You Can Safely Invest In / README

发布于 2024-06-17 01:03:19 字数 4220 浏览 0 评论 0 收藏 0

1501. 可以放心投资的国家

English Version

题目描述

表 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

 

一家电信公司想要投资新的国家。该公司想要投资的国家是:  该国的平均通话时长要严格地大于全球平均通话时长。

写一个解决方案,  找到所有该公司可以投资的国家。

返回的结果表 无顺序要求

结果格式如下例所示。

 

示例 1:

输入:
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    |
+-----------+-----------+----------+
输出:
+----------+
| 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 是唯一的平均通话时长大于全球平均通话时长的国家, 也是唯一的推荐投资的国家.

解法

方法一:等值连接 + 分组 + 子查询

我们可以使用等值连接,将 Person 表和 Calls 表连接起来,连接的条件是 Person.id = Calls.caller_id 或者 Person.id = Calls.callee_id,然后再将连接后的表和 Country 表连接起来,连接的条件是 left(phone_number, 3) = country_code,最后按照国家分组,计算每个国家的平均通话时长,然后再使用子查询,找出平均通话时长大于全球平均通话时长的国家。

# Write your MySQL query statement below
SELECT country
FROM
  (
    SELECT c.name AS country, AVG(duration) AS duration
    FROM
      Person
      JOIN Calls ON id IN(caller_id, callee_id)
      JOIN Country AS c ON LEFT(phone_number, 3) = country_code
    GROUP BY 1
  ) AS t
WHERE duration > (SELECT AVG(duration) FROM Calls);

方法二

# Write your MySQL query statement below
WITH
  T AS (
    SELECT c.name AS country, AVG(duration) AS duration
    FROM
      Person
      JOIN Calls ON id IN(caller_id, callee_id)
      JOIN Country AS c ON LEFT(phone_number, 3) = country_code
    GROUP BY 1
  )
SELECT country
FROM T
WHERE duration > (SELECT AVG(duration) FROM Calls);

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文