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

Leetcode2545:根据第 K 场考试的分数排序

题目描述:

班里有 m 位学生,共计划组织 n 场考试。给你一个下标从 0 开始、大小为 m x n 的整数矩阵 score ,其中每一行对应一位学生,而 score[i][j] 表示第 i 位学生在第 j 场考试取得的分数。矩阵 score 包含的整数 互不相同 。

另给你一个整数 k 。请你按第 k 场考试分数从高到低完成对这些学生(矩阵中的行)的排序。

返回排序后的矩阵。

代码思路:

  1. 获取输入数据的维度
    • m = len(score):获取成绩列表(二维列表)的行数,即学生人数。
    • n = len(score[0]):获取成绩列表(二维列表)的列数,即每个学生的成绩科目数。
  2. 抽取出第 k 列的成绩
    • k_score = [score[i][k] for i in range(0, m)]:使用列表推导式,从每个学生的成绩中抽取出第 k 列的成绩,形成一个新列表 k_score
  3. 创建成绩到索引的映射
    • d1 = {value:idx for idx, value in enumerate(k_score)}:创建一个字典 d1,键是第 k 列的成绩值,值是该成绩值在原列表 k_score 中的索引。这个映射用于后续根据排序后的成绩值找到原始的索引位置。
  4. 对第 k 列的成绩进行排序
    • k_score.sort():对列表 k_score 进行升序排序。
  5. 创建排序后索引到成绩的映射
    • d2 = {m - 1 - idx: value for idx, value in enumerate(k_score)}:创建一个字典 d2,键是逆序的索引(即从大到小),值是排序后的成绩值。这里逆序是为了后续方便从排序后的索引找到原始索引。由于排序是升序,所以这里通过 m - 1 - idx 转换为从大到小的索引,以便后续直接通过索引找到对应的原始成绩位置。
  6. 根据排序后的索引找到原始的学生成绩列表
    • 初始化一个空列表 ans 用于存放结果。
    • 遍历排序后的索引(从0到 m-1),通过 d2[i] 获取排序后的成绩值,然后通过 d1[d2[i]] 获取该成绩值在原始列表 k_score 中的索引(即原始的学生索引)。
    • 根据原始的学生索引,从原始的成绩列表 score 中取出相应的学生成绩列表,添加到结果列表 ans 中。
  7. 返回结果
    • return ans:返回排序后的学生成绩列表。

代码实现:

class Solution:
    def sortTheStudents(self, score: List[List[int]], k: int) -> List[List[int]]:
        # 获取行和列的长度
        m = len(score)
        n = len(score[0])
        # 抽取出列的值
        k_score = [score[i][k] for i in range(0, m)]
        # 获取值对应的索引
        d1 = {value:idx for idx, value in enumerate(k_score)}
        # 排序
        k_score.sort()
        # 获取排序后对应的索引(注意排序是升序)
        d2 = {m - 1 - idx: value for idx, value in enumerate(k_score)}
        # 按照排序后的索引对应的值,寻找到原始值对应的序号
        ans = []
        for i in range(0, m):
            ori_order = d1[d2[i]]
            ans.append(score[ori_order])

        return ans

 


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

相关文章:

  • 使用CNN模型训练图片识别(键盘,椅子,眼镜,水杯,鼠标)
  • OpenHarmony 3.2 网卡获取ip地址缓慢分析
  • 全志H618 Android12修改doucmentsui鼠标单击图片、文件夹选中区域
  • Apache Solr RCE(CVE-2017-12629)--vulhub
  • 面试题整理4----lvs,nginx,haproxy区别和使用场景
  • Spring Boot中Bean的 构造器注入、字段注入和方法注入
  • 26、基于SpringBoot的在线文档管理系统的设计与实现
  • R 基础运算
  • 基于卷积神经网络(CNN)和ResNet50的水果与蔬菜图像分类系统
  • 机器视觉检测相机基础知识 | 颜色 | 光源 | 镜头 | 分辨率 / 精度 / 公差
  • Leetcode 串联所有单词的子串
  • 【windows】sonarqube起不来的问题解决
  • 人脸修复与增强腾讯开源项目GFPGAN介绍
  • python rabbitmq实现简单/持久/广播/组播/topic/rpc消息异步发送可配置Django
  • Java爬虫实战:深度解析Lazada商品详情
  • 解决ubuntu22.04常见问题
  • Qt之串口设计-线程实现(十二)
  • 深入浅出:内网黄金票据与白银票据
  • ubuntu批量依赖库拷贝(ldd)
  • S32K324 Stack异常分析及解决方案
  • 数据结构十大排序之(冒泡,快排,并归)
  • C#.NET使用multipart/form-data方式上传文件及其他数据
  • 全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战训练一)
  • c4d动画怎么导出mp4视频,c4d动画视频格式设置
  • 网络安全基础知识分享
  • 算法—有效的字母异位词