LeetCode-602. 好友申请 II :谁有最多的好友(中等)

本文介绍了一种使用SQL查询来统计在社交网络中拥有最多朋友的用户的方法。通过将发送和接收好友请求视为两个独立过程并进行联合操作,创建了一个临时表。接着,通过分组和计数去重后的接受者ID,得到了每个用户的朋友数量。最后,利用SQL的排序和分页技巧,找到了拥有最多朋友的用户。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述
题目来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/friend-requests-ii-who-has-the-most-friends
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

本人思路:
– 1、将每一次发送邀请和接受邀请看作两个单独的过程,即使用union 将这两个过程连接,那么所有的朋友关系都在这个临时表temp中
– 2、再使用任意的一方去分组,并且统计去重后的朋友人数,即可以得到每个人有多少朋友
– 3、这里用到了一个求最值常用的技巧,即按朋友数counts排序,再使用limit分页,可得到结果

select requester_id as id ,count(distinct accepter_id)as num
from (
    select *
    from request_accepted
    union
    select accepter_id as requester_id,requester_id as accepter_id,accept_date
    from request_accepted 
)temp
group by requester_id 
order by num desc
limit 0,1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值