当前位置: 首页 > article >正文

SQL-leetcode—619. 只出现一次的最大数字

619. 只出现一次的最大数字

MyNumbers 表:

±------------±-----+
| Column Name | Type |
±------------±-----+
| num | int |
±------------±-----+
该表可能包含重复项(换句话说,在SQL中,该表没有主键)。
这张表的每一行都含有一个整数。

单一数字 是在 MyNumbers 表中只出现一次的数字。

找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null 。

查询结果如下例所示。

示例 1:

输入:
MyNumbers 表:
±----+
| num |
±----+
| 8 |
| 8 |
| 3 |
| 3 |
| 1 |
| 4 |
| 5 |
| 6 |
±----+
输出:
±----+
| num |
±----+
| 6 |
±----+
解释:单一数字有 1、4、5 和 6 。
6 是最大的单一数字,返回 6 。
示例 2:

输入:
MyNumbers table:
±----+
| num |
±----+
| 8 |
| 8 |
| 7 |
| 7 |
| 3 |
| 3 |
| 3 |
±----+
输出:
±-----+
| num |
±-----+
| null |
±-----+
解释:输入的表中不存在单一数字,所以返回 null 。

题解

单一数字 是在 MyNumbers 表中只出现一次的数字。
找出最大的 单一数字 。如果不存在 单一数字 ,则返回 null 。

分组求单次最大值:
你应该想到的是:group by order by max 、count over?

方法一

-- 总是监测无法通过,因为无数据的时候要返回null,咋返回呢?
select 
    num as num
from MyNumbers 
group by num 
having count(num)=1
order by num Desc 
limit 1

-- 找了试了下各种函数好像都不行,什么if、isnull等待
-- 最终使用了个笨方法 union 个null进来呗
-- 把null塞进来,查不出来不就剩下null了吗?
select null as num 
union 

select 
    num as num
from MyNumbers 
group by num 
having count(num)=1
order by num Desc 
limit 1

方法二 count over + max

with tmp as (
select 
    num as num
    ,count(num) over (partition by num order by num Desc) as cno
from MyNumbers 
)

select max(num) as num from tmp where cno=1

http://www.kler.cn/a/506218.html

相关文章:

  • 使用中间件自动化部署java应用
  • QT 如何禁止QComboBox鼠标滚轮
  • [系统安全] 六十一.恶意软件分析 (12)LLM赋能Lark工具提取XLM代码的抽象语法树(初探)
  • 2Spark Core
  • 【物联网】ARM核介绍
  • 本地部署Web-Check网站检测与分析利器并实现远程访问实时监测
  • 《Keras 3 在 TPU 上的肺炎分类》
  • 无人机天文导航与卫星导航相结合方面,研究创新点与课题推荐
  • 网络安全 | 什么是CC攻击防护?
  • Redis 中 TTL 的基本知识与禁用缓存键的实现策略(Java)
  • MR30分布式IO:贴标机产线的高效扩展与控制新纪元
  • Maven依赖管理项目构建工具
  • Linux安装Docker教程(详解)
  • 设计模式03:行为型设计模式之策略模式的使用情景及其基础Demo
  • 算法库里的heap算法,仿函数和模版进阶(续)
  • 【科技赋能未来】NDT2025第三届新能源数字科技大会全面启动!
  • Wireshark 使用教程:网络分析从入门到精通
  • 微信小程序:实现单选,多选,通过变量控制单选/多选
  • 人工智能之深度学习_[2]-PyTorch入门
  • 【Flink系列】4. Flink运行时架构
  • 低代码平台:技术复杂性的系统简化
  • 安装 fairseq 失败
  • leetcode刷题记录(四十八)——128. 最长连续序列
  • 【初阶数据结构】序列系统重构:顺序表
  • 易语言文字识别OCR
  • 美图脱掉“复古外衣”,在AI浪潮中蜕变