力扣之1412.查找成绩处于中游的学生

news2025/1/21 2:54:39
  • 题目:

  • sql建表语句:

  • Create table If Not Exists Student (student_id int, student_name varchar(30));
    Create table If Not Exists Exam (exam_id int, student_id int, score int);
    Truncate table Student;
    insert into Student (student_id, student_name) values ('1', 'Daniel');
    insert into Student (student_id, student_name) values ('2', 'Jade');
    insert into Student (student_id, student_name) values ('3', 'Stella');
    insert into Student (student_id, student_name) values ('4', 'Jonathan');
    insert into Student (student_id, student_name) values ('5', 'Will');
    Truncate table Exam;
    insert into Exam (exam_id, student_id, score) values ('10', '1', '70');
    insert into Exam (exam_id, student_id, score) values ('10', '2', '80');
    insert into Exam (exam_id, student_id, score) values ('10', '3', '90');
    insert into Exam (exam_id, student_id, score) values ('20', '1', '80');
    insert into Exam (exam_id, student_id, score) values ('30', '1', '70');
    insert into Exam (exam_id, student_id, score) values ('30', '3', '80');
    insert into Exam (exam_id, student_id, score) values ('30', '4', '90');
    insert into Exam (exam_id, student_id, score) values ('40', '1', '60');
    insert into Exam (exam_id, student_id, score) values ('40', '2', '70');
    insert into Exam (exam_id, student_id, score) values ('40', '4', '80');
  • 分析:首先,我们先看题,题目要求要找出没有当过第一和最后的人,没有参加过考试的不算,我们可以先按照考试id分组,按照分数排序,正序倒序都要,找出每个人在每个考试的排名,然后先取出没有得过第一和最后的人,因为这样会包含在其他考试得过第一或者最后的人,所以我们应该在取出得过第一和最后的id,筛选出在没有得过第一和最后并且也不再得过第一和最后表里的人,然后连接学生表,得到姓名。图表分析:

  • sql实现:

  • with t1 as (select exam_id,
                       student_id,
                       score,
                       rank() over (partition by exam_id order by score)      rn1,
                       --  窗口函数升序
                       rank() over (partition by exam_id order by score desc) rn2
                       -- 窗口函数降序
                from Exam),
        t2 as (
            select * from t1 where rn1 !=1 and rn2 !=1
            -- 找出没有得过第一或者最后一名的考试信息
        ),
        t3 as (
           select distinct student_id from t1 where rn1=1 or rn2 =1
           -- 找出得过第一或者最后一名的学生id
        ),
        t4 as (
            select distinct student_id from t2 where student_id not in (select * from t3)
            -- 筛选出没有得过第一或者最后一名的表里面的人不在得过第一或者最后一名的学生id
        )
    select s1.student_id,student_name from t4,Student s1 where s1.student_id=t4.student_id order by s1.student_id;
     -- 连接学生表得到姓名 并排序
  • pandas例子:

  • data = [[1, 'Daniel'], [2, 'Jade'], [3, 'Stella'], [4, 'Jonathan'], [5, 'Will']]
    student = pd.DataFrame(data, columns=['student_id', 'student_name']).astype({'student_id':'Int64', 'student_name':'object'})
    data = [[10, 1, 70], [10, 2, 80], [10, 3, 90], [20, 1, 80], [30, 1, 70], [30, 3, 80], [30, 4, 90], [40, 1, 60], [40, 2, 70], [40, 4, 80]]
    exam = pd.DataFrame(data, columns=['exam_id', 'student_id', 'score']).astype({'exam_id':'Int64', 'student_id':'Int64', 'score':'Int64'})
  • pandas实现:

  • import pandas as pd
    
    def find_quiet_students(student: pd.DataFrame, exam: pd.DataFrame) -> pd.DataFrame:
        exam['rn1']=exam.groupby('exam_id')['score'].rank('dense')
        -- 按照exam_id分组,score排序:升序 名次可以并列
    
        exam['rn2']=exam.groupby('exam_id')['score'].rank('dense',ascending=False)
        -- 按照exam_id分组,score排序:降序 名次可以并列
    
        a = exam[(exam['rn1']!=1) & (exam['rn2']!=1)]['student_id'].drop_duplicates()
        -- 找出没有得过第一或者最后一名的考试信息并去重
    
        b=exam[(exam['rn1']==1) | (exam['rn2']==1)]['student_id'].drop_duplicates()
        -- 找出得过第一或者最后一名的学生id并去重
        a=a[~a.isin(b)]
        -- 筛选出没有得过第一或者最后一名的表里面的人不在得过第一或者最后一名的学生id  注:~符号代表取反
        a=a.to_frame()
        --  转换为dataframe对象
        c=a.merge(student, how='inner', on='student_id').sort_values(['student_id'])
        -- 连接姓名表得到姓名,并按照学生ID 排序
        return c

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2218062.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

linux环境下的程序设计与git操作

目录 前言: 进度条小程序: 先介绍几个背景知识 代码实现 Git操作 总结 其他指令 前言: 本文将重点介绍1. linux下的程序设计,并使用linux下的几个函数接口。实现一个简单的小程序 2.本着开源精神,进行git操作。…

OPENSSL-2023/11/10学习记录-C/C++对称分组加密DES

对称分组加密常用算法: DES 3DES AES 国密SM4 对称分组加密应用场景: 文件或者视频加密 加密比特币私钥 消息或者配置项加密 SSL通信加密 对称分组加密 使用异或实现一个简易的对称加密算法 A明文 B秘钥 AB密文AB (AB)B A 密码补全和初始化 数…

在Access中执行SQL语句

1.新建一个查询 2. 关闭弹出的窗口,创建一个空查询 3. 在“设计”页中点击“数据定义”进入输入SQL语句界面 4. “执行”后就能看到执行结果 5.如果想再次执行SQL,则可在MDI窗口标题栏右键,在弹出的菜单中选择“SQL 视图”即可

Vue向上滚动加载数据时防止内容闪动

目前的需求:当前组件向上滚动加载数据,dom加载完后,页面的元素位置不能发生变化 遇到的问题:加载完数据后,又把滚轮滚到之前记录的位置时,内容发生闪动 现在的方案: 加载数据之前记录整体滚动条…

Spring AI 整体介绍_关键组件快速入门_prompt_embedding等

Spring AI:Java开发者的AI集成新利器 在过去,Java开发者在构建AI应用时面临着缺乏统一框架的问题,导致不同AI服务的集成过程复杂且耗时。Spring AI应运而生,旨在为基于Java的应用程序提供一个标准化、高效且易于使用的AI开发平台…

51单片机的超声波视力保护仪【proteus仿真+程序+报告+原理图+演示视频】

1、主要功能 该系统由AT89C51/STC89C52单片机LCD1602显示模块温度传感器光照传感器超声波传感器按键、LED、蜂鸣器等模块构成。适用于视力保护仪、坐姿矫正器、超声波防近视等相似项目。 可实现功能: 1、LCD1602显示温度、光照、距离和学习时间 2、超声波传感器采集头部与探…

如何做好SQL 数据库安全

随着信息技术的迅猛发展,数据库在现代信息系统中的重要性日益凸显。无论是电子商务平台、金融系统还是社交媒体应用,数据库都是其核心组件之一。其中,SQL(Structured Query Language,结构化查询语言)数据库…

效率飞跃 | SOLIDWORKS 2025:草图与装配体设计再升级!

一年一度的SOLIDWORKS新版本已经发布,快来看看SOLIDWORKS 2025这些让您眼前一亮的新功能,它们将为您的研发过程增添强大助力。 一、草图绘制 1、通过 XYZ 点生成的曲线可以选取坐标系统 新版本可选择曲线起点位置 2、转换实体作为构造几何体 转换实体…

Science Robotics 通过新材料打造FiBa软机器人 可实现四种形态进化

近几年由于材料科学的进步,软机器人相关技术近几年研究成果显著,与传统的刚性机器人相比,软机器人的设计灵感来源于自然界中的生物系统,如蠕虫、章鱼、壁虎和青蛙等。这些生物利用柔软、有弹性的材料,在复杂环境中展现…

微服务基础架构(图)

微服务基础架构是一种现代化的软件架构模式,旨在将大型复杂的应用程序拆分为多个小型、独立的服务。每个微服务专注于特定的业务功能,可独立开发、部署和扩展。 在微服务基础架构中,通常会使用轻量级的通信机制,如 RESTful API 或…

C++简易日志系统:打造高效、线程安全的日志记录工具

目录 引言: 1.日志的基本概念 1.1.什么是日志? 1.2.我们为什么需要日志? 2.自己实现一个简易日志 2.1.日志的等级 2.2日志的格式 2.3.获取时间的方法 2.4.日志的主体实现 参数: 代码解析: 问题&#xff1a…

C++新手入门指南:从基础概念到实践之路

C 继承了 C 语言的高效性和灵活性,同时新增了面向对象编程的特点。这使得 C 既可以进行底层系统编程,又能进行面向对象的软件设计。在面向对象编程方面,C 支持封装、继承和多态三大特性。 💯C 初印象 语言的发展就像是练功打怪…

用Java爬虫API,轻松获取电商商品SKU信息

在电子商务的精细化运营时代,SKU信息的重要性不言而喻。SKU(Stock Keeping Unit)信息不仅包含了商品的规格、价格、库存等关键数据,还直接影响到库存管理、价格策略和市场分析等多个方面。如何高效、准确地获取这些信息&#xff0…

STM32—SPI通信外设

1.SPI外设简介 STM32内部集成了硬件SPI收发电路,可以由硬件自动执行时钟生成、数据收发等功能,减轻CPU的负担可配置8位/16位数据帧、高位先行/低位先行时钟频率:fpclk/(2,4,8,16,32,64,128,256)支持多主机模型、主或从操作可精简为半双工/单…

【GESP】C++一级练习BCQM3049,细胞分裂

GESP一级知识点整形int和for循环练习。 题目题解详见:【GESP】C一级练习BCQM3049,细胞分裂 | OneCoder 【GESP】C一级练习BCQM3049,细胞分裂 | OneCoderGESP一级知识点整形int和for循环练习。https://www.coderli.com/gesp-1-bcqm3049/ C …

微服务--Ribbon负载均衡器

Nacos 本身里面就内置了Rabbion, 所以 不需要额外添加 添加LoadBalanced注解: Rabbion 内置的有好几种 负载均衡器 可以根据业务去选择,我们一般不会额外配置 都是默认的轮询,因为我们是基于docker发布的 大家的资源都是平等的 若…

Vue.js + Element UI 实现多方式登录功能(账号/手机号验证码登录)

引言 在现代Web应用中,提供多种登录方式已成为一种标准做法,这不仅能提升用户体验,还能满足不同用户的需求。本文将详细介绍如何使用Vue.js框架结合Element UI组件库,实现一个包含账号登录和手机号验证码登录两种方式的登录页面。…

Leetcode 单词规律

即判断给定的模式字符串(pattern)和单词字符串(s)是否遵循相同的对应规则。具体来说,就是要判断 pattern 中的字符与 s 中的单词是否存在一一对应的关系,即双射(bijection)。 算法思…

ant design vue TimePicker时间选择器不点击确认也可以设置值

文章目录 前言一、背景二、操作步骤1.复现前的准备工作(1)vue版本和ant design vue 版本(2)任意ant design vue TimePicker的demo 2.解决问题(1)使用change时间(无效)(2&…

【学习】word保存图片

word中有想保存的照片 直接右键另存为的话,文件总是不清晰,截屏的话,好像也欠妥。 怎么办? 可以另存为 网页 .html 可以得到: 原图就放到了文件夹里面