出现三次以上相同积分的情况题解

出现三次以上相同积分的情况

https://www.nowcoder.com/practice/c69ac94335744480aa50646864b7f24d?tpId=82&tags=&title=&diffculty=0&judgeStatus=0&rp=1

方法一:要三次以上的积分,那么肯定要查找3个id不同但是积分相同的情况,怎么比较一列和另外一列是否相等呢?在一个表里面感觉无法做到,那么最简单就是利用笛卡尔积了,1个表看成3个表,联立三个表number相同的部分
,笛卡尔积如下:

第1个表
第2个表
第3个表
id number id number id number
1 111 1
111 1 111
2
333 2 333 2 333
3
111 3 111 3 111
4
111 4 111 4 111
5 333 5 333 5 333
那么可能就是举例一种情况就是寻找第1个表id为1的111,寻找第2个表id为3的111,寻找第3个表id4为的111,那么就找到一个111,输出111
但是上面这种找法可能会有重复的,比如第1个表id为3的111,寻找第2个表id为1的111,寻找第3个表id4为的111,那么又找到一个111,所以要去重。代码如下:
SELECT  DISTINCT g1.number AS times
FROM
    grade g1,
    grade g2,
    grade g3
WHERE
    g1.id != g2.id
    AND g2.id != g3.id 
    AND g1.id !=g3.id
    AND g1.number = g2.number
    AND g2.number = g3.number
;


方法二:
使用group by 将积分分组,然后用having找到积分的个数大于等于3的:
select number from grade group by number having count(*)>=3


全部评论
方法二 "number" 少打了 "ber"
2 回复 分享
发布于 2020-09-18 00:32
方法一投机取巧了,这实质上是“找出现了3次的积分”。如果表里有积分出现4次或者更多就不行了。
1 回复 分享
发布于 2021-04-09 15:51
第一种方法里画的图也不是笛卡尔积
1 回复 分享
发布于 2022-05-02 14:48
哪有这么复杂啊,只是看分数出现的次数吧,分组计数就行吧我觉得。
2 回复 分享
发布于 2021-08-31 16:18
第一种解决真是一言难尽
2 回复 分享
发布于 2022-03-01 15:24
和方法二类似的 select number from grade where count(*)>=3 group by number 这样怎么就不能通过呢?
点赞 回复 分享
发布于 2021-12-21 17:20
第二种在后面加order by,少了排序
点赞 回复 分享
发布于 2022-03-18 10:46

相关推荐

头像
03-25 16:22
南华大学 Java
点赞 评论 收藏
分享
02-26 15:33
已编辑
西北大学 golang
点赞 评论 收藏
分享
评论
64
2
分享

创作者周榜

更多
牛客网
牛客企业服务