矩阵中幸运数(Python)

给你一个 m * n 的矩阵,矩阵中的数字 各不相同 。请你按 任意 顺序返回矩阵中的所有幸运数。
幸运数 是指矩阵中满足同时下列两个条件的元素:在同一行的所有元素中最小

在同一列的所有元素中最大

示例 1:输入:matrix = [[3,7,8],[9,11,13],[15,16,17]],输出:[15]

解释:15 是唯一的幸运数,因为它是其所在行中的最小值,也是所在列中的最大值。

示例 2:输入:matrix = [[1,10,4,2],[9,3,8,7],[15,16,17,12]],输出:[12]

解释:12 是唯一的幸运数,因为它是其所在行中的最小值,也是所在列中的最大值。

示例 3:输入:matrix = [[7,8],[1,2]],输出:[7]

解释:7是唯一的幸运数字,因为它是行中的最小值,列中的最大值。

解题思路:

首先分别返回一个含有每行中最小元素的列表与每列中最大元素的列表;

遍历整个列表,判断数是否是一行中最小的同时又是一列中最大的元素,最后返回result的列表即可。

python 复制代码
class Solution:
    def luckyNumbers(self,matrix:List[List[int]])->List[int]:
        m=len(matrix)
        n=len(matrix[0])
        min_row=[]
        max_col=[]
        
        for i in range(m):
            min_rpw.append(min(matrix[i]))
        for j in range(n):
            max_1=0
            for i in range(m):
                if matrix[i][j]>max_1:
                    max_1=matrix[i][j]
            max_col.append(max_1)
 
        result=[]
        for i in range(m):
            for j in range(n):
                if matrix[i][j]==min_row[i] and martix[i][j]==max_col[j]:
                    result.append(matrix[i][j])
        return result

例子:

python 复制代码
arr=[[10,36,52],
[33,24,88],
[66,76,99]]

#获取矩阵的元素个数,也就是行数
row=len(arr) #row=3
print("行数:{}".format(row))
#获取矩阵的列数数,也就是一维数组中的元素个数
col=len(arr[0]) #col=3
print("列数:{}".format(col))

#有多少行就有多少个行最小值,minrow[col],来进行统计col取值为0..row
#同理有多少个列就有多少个列最大值,用maxcol[col],来进行统计col取值为0..col
#先赋初值,题目是0到1024,那就可以让最小值初值为最大,最大值初值为最小
minrow=[1024]*row
for i in range(row):
    print(minrow[i])
#这里就是把minrow[0]=1024,minrow[1]=1024,minrow[2]=1024
maxcol=[0]*col
for i in range(col):
    print(maxcol[i])
#这里就是把mincol[0]=0,mincol[1]=0,mincol[2]=0
#这个容易理解,要求最小,我就拿个最大的和你比,如果比我小,让换成小的,直到找到最小,同理找到最大的也是这样

#i为行号,j为列号
for i in range(row):
    for j in range(col):
        print(i,j,arr[i][j])
        minrow[i]=min(arr[i][j],minrow[i]) #第一次让arr[0,0]=10和minrow[0]=1024进行对比,取小的minrow[0]=10,以此类推
        maxcol[j]=max(arr[i][j],maxcol[j]) #第一次让arr[0,0]=10和maxrow[0]=0进行对比,取大的maxrow[0]=10,以此类推,一个元素即是在行i里面,同时又在列j里面,所以同时比较

        #通过上面比较,我们获取了minrow[0]=10,minrow[1]=24,minrow[2]=66,
        #通过上面比较,我们获取了maxcol[0]=66,maxcol[1]=76,maxcol[3]=99
        #接下来获取幸运数就容易了,两两比较有相等的就可以了
for i in range(row):
    for j in range(col):
        if minrow[i]==maxcol[j]:
            print("幸运数是:",minrow[i])

程序运行结果:

复制代码
行数:3
3
1024
1024
1024
0
0
0
0 0 10
0 1 36
0 2 52
1 0 33
1 1 24
1 2 88
2 0 66
2 1 76
2 2 99
幸运数是: 66
相关推荐
上弦月-编程1 分钟前
【C语言】函数栈帧的创建与销毁(底层原理)
c语言·开发语言
MATLAB代码顾问2 分钟前
混合粒子群-模拟退火算法(HPSO-SA)求解作业车间调度问题——附MATLAB代码
算法·matlab·模拟退火算法
eqwaak04 分钟前
PyTorch张量操作全攻略:从入门到精通
开发语言·人工智能·pytorch·python
辞旧 lekkk6 分钟前
【Qt】初识(上)
开发语言·数据库·qt·学习·萌新
Felven7 分钟前
C. Prefix Min and Suffix Max
算法
加农炮手Jinx7 分钟前
LeetCode 26. Remove Duplicates from Sorted Array 题解
算法·leetcode·力扣
加农炮手Jinx7 分钟前
LeetCode 88. Merge Sorted Array 题解
算法·leetcode·力扣
A懿轩A8 分钟前
Ghostty:告别 Mac 毛坯终端,打造 2026 最丝滑的 Ghostty AI 开发驾驶舱——Claude Code 团队也在用
python·macos·策略模式
格林威8 分钟前
线阵工业相机:如何计算线阵相机的行频(Line Rate)?公式+实例
开发语言·人工智能·数码相机·算法·计算机视觉·工业相机·线阵相机
Chasing Aurora9 分钟前
python 安装依赖和导入模块 详解
开发语言·python·虚拟环境·import·pyenv·requirements