news 2026/2/13 9:44:09

力扣1783-大满贯数量

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣1783-大满贯数量

表:Players

+----------------+---------+ | Column Name | Type | +----------------+---------+ | player_id | int | | player_name | varchar | +----------------+---------+ player_id 是这个表的主键(具有唯一值的列) 这个表的每一行给出一个网球运动员的 ID 和 姓名

表:Championships

+---------------+---------+ | Column Name | Type | +---------------+---------+ | year | int | | Wimbledon | int | | Fr_open | int | | US_open | int | | Au_open | int | +---------------+---------+ year 是这个表的主键(具有唯一值的列) 该表的每一行都包含在每场大满贯网球比赛中赢得比赛的球员的 ID

编写解决方案,找出每一个球员赢得大满贯比赛的次数。结果不包含没有赢得比赛的球员的ID 。

结果集无顺序要求

结果的格式,如下所示。

示例 1:

输入:Players 表: +-----------+-------------+ | player_id | player_name | +-----------+-------------+ | 1 | Nadal | | 2 | Federer | | 3 | Novak | +-----------+-------------+ Championships 表: +------+-----------+---------+---------+---------+ | year | Wimbledon | Fr_open | US_open | Au_open | +------+-----------+---------+---------+---------+ | 2018 | 1 | 1 | 1 | 1 | | 2019 | 1 | 1 | 2 | 2 | | 2020 | 2 | 1 | 2 | 2 | +------+-----------+---------+---------+---------+输出:+-----------+-------------+-------------------+ | player_id | player_name | grand_slams_count | +-----------+-------------+-------------------+ | 2 | Federer | 5 | | 1 | Nadal | 7 | +-----------+-------------+-------------------+解释:Player 1 (Nadal) 获得了 7 次大满贯:其中温网 2 次(2018, 2019), 法国公开赛 3 次 (2018, 2019, 2020), 美国公开赛 1 次 (2018)以及澳网公开赛 1 次 (2018) 。 Player 2 (Federer) 获得了 5 次大满贯:其中温网 1 次 (2020), 美国公开赛 2 次 (2019, 2020) 以及澳网公开赛 2 次 (2019, 2020) 。 Player 3 (Novak) 没有赢得,因此不包含在结果集中。

思路:

1、整理所有大满贯冠军记录
题目中大满贯冠军分别存放在不同的字段中,包括温网、法网、美网和澳网。为了便于统计,需要将这四个字段中的冠军记录合并到同一个结果集中,使每一行只代表一次夺冠记录。

2、合并不同赛事的冠军数据
通过将四项赛事的冠军列依次合并,形成一个统一的冠军列表。这样处理后,每位球员每获得一次大满贯冠军,就会在结果集中对应一条记录。

3、关联球员基本信息
将合并后的冠军记录与球员表进行关联,通过球员 ID 获取球员姓名等基本信息,从而明确每一条冠军记录属于哪位球员。

4、按球员维度进行统计
以球员 ID 和球员姓名为分组条件,对冠军记录进行计数。统计结果表示每位球员获得大满贯冠军的总次数。

5、输出最终结果
最终返回球员编号、球员姓名以及对应的大满贯冠军次数,得到每位球员的 Grand Slam 冠军数量统计结果。

代码:

select player_id , player_name, count(*) as grand_slams_count from players t1 join (select wimbledon from Championships union all select fr_open from Championships union all select us_open from Championships union all select au_open from Championships) t2 on t1.player_id = t2.Wimbledon group by player_id,player_name
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/6 9:06:35

抖音批量下载终极指南:快速掌握自动化视频采集技巧

抖音批量下载终极指南:快速掌握自动化视频采集技巧 【免费下载链接】douyinhelper 抖音批量下载助手 项目地址: https://gitcode.com/gh_mirrors/do/douyinhelper 还在为一个个手动保存抖音视频而烦恼吗?抖音批量下载助手让你彻底告别重复劳动&am…

作者头像 李华
网站建设 2026/2/11 15:23:47

VMware macOS解锁工具unlocker使用指南

VMware macOS解锁工具unlocker使用指南 【免费下载链接】unlocker VMware Workstation macOS 项目地址: https://gitcode.com/gh_mirrors/un/unlocker unlocker是一款专为VMware Workstation设计的macOS虚拟机解锁工具,通过修改VMware配置文件,添…

作者头像 李华
网站建设 2026/2/13 22:11:45

老Mac升级最新系统:OpenCore Legacy Patcher实战指南

老Mac升级最新系统:OpenCore Legacy Patcher实战指南 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 还在为老款Mac无法安装新版macOS而困扰?通过O…

作者头像 李华
网站建设 2026/2/13 19:12:23

付费墙绕过工具终极指南:5步轻松解锁优质内容

你是否经常遇到这样的情况:打开一篇深度分析文章,正看到关键处却被付费墙拦住?别担心,Bypass Paywalls Clean这款强大的浏览器扩展工具,正是为你解决这个困扰而生。它能智能识别并绕过各类付费限制,让你无缝…

作者头像 李华
网站建设 2026/2/10 3:25:22

内容解锁工具完全操作手册:从新手到专家的快速进阶指南

内容解锁工具完全操作手册:从新手到专家的快速进阶指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 在信息获取日益受限的今天,内容解锁工具成为了打破知识…

作者头像 李华
网站建设 2026/2/8 20:20:33

Ollama下载本地模型库添加Qwen3-VL-8B的具体步骤

Ollama下载本地模型库添加Qwen3-VL-8B的具体步骤 在当前AI应用向终端下沉的大趋势下,越来越多企业希望将视觉理解能力部署到本地环境,而非依赖云端API。尤其是在涉及用户隐私或敏感图像数据的场景中——比如医疗影像辅助分析、电商商品审核、智能客服截…

作者头像 李华