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

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

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

相关推荐

02-26 16:52
门头沟学院 Java
Lunarloop:董事长亲自到ssob来要IM项目的技术方案来了
点赞 评论 收藏
分享
会飞的猿:我看你想进大厂,我给你总结一下学习路线吧,java语言方面常规八股要熟,那些java的集合,重点背hashmap八股吧,jvm类加载机制,运行时分区,垃圾回收算法,垃圾回收器CMS、G1这些,各种乐观锁悲观锁,线程安全,threadlocal这些。在进阶一些的比如jvm参数,内存溢出泄漏排查,jvm调优。我这里说的只是冰山一角,详细八股可以去网上找,这不用去买,都免费资源。mysql、redis可以去看小林coding,我看你简历上写了,你一定要熟,什么底层b+树、索引结构、innodb、mvcc、undo log、redo log、行级锁表级锁,这些东西高频出现,如果面试官问我这些我都能笑出来。消息队列rabbitmq也好kafka也好,学一种就行,什么分区啊副本啊确认机制啊怎么保证不重复消费、怎么保证消息不丢失这些基本的一定要会,进阶一点的比如LEO、高水位线、kafka和rocketmq底层零拷贝的区别等等。计算机网络和操作系统既然你是科班应该理解起来问题不大,去看小林coding这两块吧,深度够了。spring boot的八股好好看看吧,一般字节腾讯不这么问,其他的java大厂挺爱问的,什么循环依赖啥的去网上看看。数据结构的话科班应该问题不大,多去力扣集中突击刷题吧。项目的话其实说白了还是结合八股来,想一想你写的这些技术会给你挖什么坑。除此之外,还有场景题、rpc、设计模式、linux命令、ddd等。不会的就别往简历上写了,虽然技术栈很多的话好看些,但背起来确实累。总结一下,多去实习吧,多跳槽,直到跳到一个不错的中厂做跳板,这是一条可行的进大厂的路线。另外,只想找个小厂的工作的话,没必要全都照这些准备,太累了,重点放在框架的使用和一些基础八股吧。大致路线就这样,没啥太多难度,就是量大,你能达到什么高度取决于你对自己多狠,祝好。
点赞 评论 收藏
分享
评论
64
2
分享

创作者周榜

更多
牛客网
牛客企业服务