力扣2965. 找出缺失和重复的数字

题目:

给你一个下标从 0 开始的二维整数矩阵 grid,大小为 n * n ,其中的值在 [1, n²] 范围内。除了 a 出现两次,b 缺失 之外,每个整数都恰好出现一次 。

任务是找出重复的数字a 和缺失的数字 b 。

返回一个下标从 0 开始、长度为 2 的整数数组 ans,其中 ans[0] 等于a,ans[1] 等于b。

提示:

  • 2 <= n == grid.length == grid[i].length <= 50
  • 1 <= grid[i][j] <= n * n
  • 对于所有满足1 <= x <= n * nx ,恰好存在一个 x 与矩阵中的任何成员都不相等。
  • 对于所有满足1 <= x <= n * nx ,恰好存在一个 x 与矩阵中的两个成员相等。
  • 除上述的两个之外,对于所有满足1 <= x <= n * nx ,都恰好存在一对 i, j 满足 0 <= i, j <= n - 1grid[i][j] == x

思路:

用字典记录从1到n²的每个值出现的次数,键值对为[数字:出现次数]。然后在字典中找到值为0(缺失)或2(重复)对应的键即可。代码如下:

python 复制代码
class Solution:
    def findMissingAndRepeatedValues(self, grid: List[List[int]]) -> List[int]:
        n = len(grid)
        ans = [0, 0]
        num_dict = {i:0 for i in range(1, n*n+1)}   # 数字:出现次数
        # 遍历矩阵,更新字典中的值
        for row in grid:
            for num in row:
                num_dict[num] += 1
        # 找到字典中值为0或2对应的键
        for key, values in num_dict.items():
            if values == 2:
                ans[0] = key
            if values == 0:
                ans[1] =key
        return ans

提交通过:

相关推荐
lifallen1 天前
Hadoop MapOutputBuffer:Map高性能核心揭秘
java·大数据·数据结构·hadoop·算法·apache
空影星1 天前
Pot Translator,跨平台划词翻译与OCR工具
python·ocr·电脑
不枯石1 天前
Python实现点云法向量各种方向设定
python·计算机视觉·numpy
JiayinX1 天前
django连接minio实现文件上传下载(提供接口示例)
后端·python·django
溟洵1 天前
【 C/C++ 算法】入门动态规划-----一维动态规划基础(以练代学式)
c语言·c++·算法
过河卒_zh15667661 天前
9.12AI简报丨腾讯投资AI游戏平台,B站开源AniSora V3
人工智能·算法·游戏·aigc·算法备案·生成合成类算法备案
boonya1 天前
Java垃圾回收机制理论算法及使用
jvm·算法·gc·垃圾收集器·理论
愚润求学1 天前
【贪心算法】day9
c++·算法·leetcode·贪心算法
Python图像识别1 天前
63_基于深度学习的草莓病害检测识别系统(yolo11、yolov8、yolov5+UI界面+Python项目源码+模型+标注好的数据集)
python·深度学习·yolo
lingran__1 天前
速通ACM省铜第二天 赋源码(Adjacent XOR和Arboris Contractio)
c++·算法