前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >LeetCode MySQL 597. 好友申请 I :总体通过率

LeetCode MySQL 597. 好友申请 I :总体通过率

作者头像
Michael阿明
发布于 2021-02-19 01:59:16
发布于 2021-02-19 01:59:16
50100
代码可运行
举报
运行总次数:0
代码可运行

文章目录

1. 题目

在 Facebook 或者 Twitter 这样的社交应用中,人们经常会发好友申请也会收到其他人的好友申请。现在给如下两个表:

表: friend_request

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
| sender_id | send_to_id |request_date|
|-----------|------------|------------|
| 1         | 2          | 2016_06-01 |
| 1         | 3          | 2016_06-01 |
| 1         | 4          | 2016_06-01 |
| 2         | 3          | 2016_06-02 |
| 3         | 4          | 2016-06-09 |

表: request_accepted

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
| requester_id | accepter_id |accept_date |
|--------------|-------------|------------|
| 1            | 2           | 2016_06-03 |
| 1            | 3           | 2016-06-08 |
| 2            | 3           | 2016-06-08 |
| 3            | 4           | 2016-06-09 |
| 3            | 4           | 2016-06-10 |

写一个查询语句,求出好友申请的通过率,用 2 位小数表示。 通过率由接受好友申请的数目除以申请总数。

对于上面的样例数据,你的查询语句应该返回如下结果。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
|accept_rate|
|-----------|
|       0.80|

注意: 通过的好友申请不一定都在表 friend_request 中。 在这种情况下,你只需要统计总的被通过的申请数(不管它们在不在原来的申请中),并将它除以申请总数,得到通过率 一个好友申请发送者有可能会给接受者发几条好友申请,也有可能一个好友申请会被通过好几次。 这种情况下,重复的好友申请只统计一次。 如果一个好友申请都没有,通过率为 0.00 。

解释: 总共有 5 个申请,其中 4 个是不重复且被通过的好友申请,所以成功率是 0.80 。

进阶: 你能写一个查询语句得到每个月的通过率吗? 你能求出每一天的累计通过率吗?

来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/friend-requests-i-overall-acceptance-rate 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

2. 解题

  • distinct 多列去重
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# Write your MySQL query statement below
select 
    ifnull
    (round(
        count(distinct requester_id, accepter_id)
        /
        count(distinct sender_id, send_to_id)
        , 2), 0) as accept_rate
from friend_request req, request_accepted acc

448 ms

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/07/19 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档