【刷题】【力扣】【180】【中等】连续出现的数字

### 文章目录

  • [@[toc]](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [题目描述](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [示例](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [输入](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [输出](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [解释](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [MySQL实现](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [方法1](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [方法2](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)
  • [Pandas实现](#文章目录 @[toc] 题目描述 示例 输入 输出 解释 MySQL实现 方法1 方法2 Pandas实现)

题目描述


  • 表:Logs
shell 复制代码
+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| id          | int     |
| num         | varchar |
+-------------+---------+
在 SQL 中, id 是该表的主键
id 是一个自增列
  • 找出所有至少连续出现三次的数字
  • 返回的结果表中的数据可以按任意顺序排列

示例


输入

  • Logs
shell 复制代码
+----+-----+
| id | num |
+----+-----+
| 1  | 1   |
| 2  | 1   |
| 3  | 1   |
| 4  | 2   |
| 5  | 1   |
| 6  | 2   |
| 7  | 2   |
+----+-----+

输出

shell 复制代码
+-----------------+
| ConsecutiveNums |
+-----------------+
| 1               |
+-----------------+

解释

  • 1 1 1是唯一连续出现至少三次的数字

MySQL实现


方法1

sql 复制代码
select distinct num as ConsecutiveNums
from (select *, lead(rn, 2) over (partition by num order by rn) as rn_lead
      from (select num, row_number() over () as rn from Logs) t1) t2
where rn_lead - rn = 2;

方法2

sql 复制代码
select distinct num as ConsecutiveNums
from (select num,
             row_number() over ()                             as rn1,
             row_number() over (partition by num order by id) as rn2
      from Logs
      order by num, id) t
group by num, rn1 - rn2
having count(rn1 - rn2) >= 3;

Pandas实现


python 复制代码
# -*- coding: utf-8 -*-
# @Time     : 2025/1/12 1:30
# @Author   : 从心
# @File     : 180.py
# @Software : PyCharm

import pandas as pd


def consecutive_numbers(logs: pd.DataFrame) -> pd.DataFrame:
    if logs.empty:
        return pd.DataFrame(columns=['ConsecutiveNums'])

    logs['rn'] = logs.reset_index(drop=True).index + 1

    grouped = logs.groupby('num')
    result = []
    for name, group in grouped:
        group = group.copy()
        group['rn_lead'] = group['rn'].shift(-2)
        result.append(group)

    df = pd.concat(result)
    df = df[df['rn_lead'] - df['rn'] == 2]

    return df['num'].drop_duplicates().to_frame(name='ConsecutiveNums')

相关推荐
学编程的小程2 天前
LeetCode2595
算法·力扣
幼儿园口算大王3 天前
最简单的难题——游戏英雄升级潜力评估
java·算法·刷题
闻缺陷则喜何志丹9 天前
【C++前缀和 排序】891. 子序列宽度之和|2182
c++·算法·前缀和·力扣·排序·子序列·宽度
白白糖16 天前
Day 27 卡玛笔记
python·力扣
白白糖18 天前
Day 28 卡玛笔记
python·算法·力扣
闻缺陷则喜何志丹1 个月前
【C++图论 并集查找】2492. 两个城市间路径的最小分数|1679
c++·算法·力扣·图论·路径·最小·分数
闻缺陷则喜何志丹1 个月前
【C++图论】2685. 统计完全连通分量的数量|1769
c++·算法·力扣·图论·数量·完全·连通分量
小殷要努力刷题!1 个月前
每日一刷——1.20——准备蓝桥杯
java·学习·算法·蓝桥杯·刷题·牛客·语法学习
L~river1 个月前
SQL刷题快速入门(三)
数据库·sql·mysql·笔试·刷题