利用matlab寻找矩阵中最大值及其位置

目录

  • 一、问题描述
    • [1.1 max函数用法](#1.1 max函数用法)
    • [1.2 MATLAB中 : : :的作用](#1.2 MATLAB中 : : :的作用)
    • [1.3 ind2sub函数用法](#1.3 ind2sub函数用法)
  • 二、实现方法
    • [2.1 方法一:max和find](#2.1 方法一:max和find)
    • [2.2 方法二:max和ind2sub](#2.2 方法二:max和ind2sub)
    • [2.3 方法对比](#2.3 方法对比)
  • 三、参考文献

一、问题描述

matlab中求最大值可使用函数max,对于一维向量,利用max函数可以直接得到向量中的最大值及其所在位置,但对于矩阵,则需要根据max函数的用法,借助其他函数共同进行处理。

1.1 max函数用法

1.找出向量中的最大值及其位置

matlab 复制代码
A = [8, 1, 6, 9, 3];
[maxVal,Idx] = max(A);
disp(maxVal);   % 输出: 9
disp(Idx);      % 输出: 4

2.找出矩阵中每列的最大值及其位置

matlab 复制代码
A = [8, 1, 6; 3, 5, 7; 4, 9, 2];
[maxValCol,IdxCol] = max(A);
%[maxValCol,IdxCol] = max(A,[],1);
disp(maxValCol);    % 输出: [8, 9, 7]
disp(IdxCol);       % 输出: [1, 3, 2]

max(A)默认找出矩阵中每列的最大值,与max(A,[],1)等效。

3.找出矩阵中每行的最大值及其位置

matlab 复制代码
A = [8, 1, 6; 3, 5, 7; 4, 9, 2];
[maxValRow,IdxRow] = max(A,[],2);
disp(maxValRow);    % 输出: [8, 7, 9]
disp(IdxRow);       % 输出: [1, 3, 2]

1.2 MATLAB中 : : :的作用

对于一个二维矩阵A = [8, 1, 6; 3, 5, 7; 4, 9, 2];利用 : : :可将矩阵转换为一个列向量B = [8;3;4;1;5;9;6;7;2]。

1.3 ind2sub函数用法

ind2sub 函数用于将线性索引转换为多维数组索引。例如将一维向量中某个元素所在的下标转换为其在对应大小数组中的行索引和列索引。

假设有一个向量A,第7个元素为数字8,将其转换到具有4行3列的矩阵B中,利用ind2sub可以获得其在该数组中的行索引为3和列索引为2。

matlab 复制代码
A = [16;5;9;4;2;11;8;14;3;10;6;15];
B = [16, 2, 3;
     5,11,10;
     9,8,6;
     4,14,15];
[rowLen,colLen] = size(B);
linearIdx = 7;
[rowIdx, colIdx] = ind2sub([rowLen,colLen], linearIdx);
disp(['RowIdx: ', num2str(rowIdx), ', ColIdx: ', num2str(colIdx)]);

ind2sub可以实现该功能的底层原理是,在matlab中数据是按列优先进行存储的,线性索引与二维矩阵中行和列的下标有以下关系:

matlab 复制代码
rowIdx = mod(linearIdx,rowLen);      % 取余数
colIdx = ceil(linearIdx/rowLen);     % 向上取整
disp(['RowIdx: ', num2str(rowIdx), ', ColIdx: ', num2str(colIdx)]);

二、实现方法

2.1 方法一:max和find

  1. 找到矩阵的最大值:
    max_val = max(A( : : :));
    这里,A( : : :) 将矩阵转换为一个列向量,max 函数返回该向量中的最大值。
  2. 找到最大值的位置:

    row, col\] = find(A == max_val); find 函数返回所有等于最大值的元素的位置。如果矩阵中有多个相同最大值,row 和 col 将包含所有这些位置的索引。

    first_row = row(1);
    first_col = col(1);

2.2 方法二:max和ind2sub

  1. 找到最大值及其索引:

    max_val , idx\] = max(A( : : :)); max 函数返回最大值及其在展开向量中的索引 idx。

    row, col\] = ind2sub(size(A), idx); ind2sub 函数根据矩阵的大小将线性索引 idx 转换为对应的行和列索引。

第一种方法可能更直观,但如果有多个相同最大值的情况,可能会返回多个位置,这时候可能需要额外处理,只取第一个出现的位置。而第二种方法则直接给出了唯一的索引,因为max函数返回的是第一个出现的最大值的位置。

三、参考文献

1\] [MATLAB 求一个矩阵的最大值极其所在位置](https://blog.csdn.net/xdg15294969271/article/details/114445200) \[2\] [matlab 找矩阵中每行或每列的最大值和最小值](https://blog.csdn.net/u013925378/article/details/88709863) \[3\] [matlab查找矩阵最大(小)值,并找到所在位置](https://wenku.csdn.net/answer/19c2544d7eb7f654a86cd96fc0ea0e5b)

相关推荐
皮皮哎哟6 分钟前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒15 分钟前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝
vortex529 分钟前
几种 dump hash 方式对比分析
算法·哈希算法
aini_lovee40 分钟前
MATLAB基于小波技术的图像融合实现
开发语言·人工智能·matlab
lbb 小魔仙1 小时前
面向 NPU 的高性能矩阵乘法:CANN ops-nn 算子库架构与优化技术
线性代数·矩阵·架构
空白诗1 小时前
CANN ops-nn 算子解读:大语言模型推理中的 MatMul 矩阵乘实现
人工智能·语言模型·矩阵
3GPP仿真实验室2 小时前
【Matlab源码】6G候选波形:OFDM-IM 增强仿真平台 DM、CI
开发语言·matlab·ci/cd
Wei&Yan2 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
团子的二进制世界2 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
吃杠碰小鸡2 小时前
高中数学-数列-导数证明
前端·数学·算法