题目来源:力扣(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