面试题 17.24. 最大子矩阵

1.题目描述

给定一个正整数、负整数和 0 组成的 N × M 矩阵,编写代码找出元素总和最大的子矩阵。
返回一个数组 [r1, c1, r2, c2],其中 r1, c1 分别代表子矩阵左上角的行号和列号,r2, c2 分别代表右下角的行号和列号。若有多个满足条件的子矩阵,返回任意一个均可。
注意:本题相对书上原题稍作改动
示例:
在这里插入图片描述
说明:
1 <= matrix.length, matrix[0].length <= 200

2.思路

需要将二维转化为一维,对于矩阵的每一列,我们将其加在一起,成为了一维上的一个数,二维矩阵的和转化为了一维数组的和。
在这里插入图片描述
这样我们就将二维问题转化为了一维问题,现在另一个问题就是怎么把所有情况都遍历到呢?
我们以第i行为第一行,向下延申,设最后一行为第j行,我们就在i这么一个范围内,将二维问题转化为一维问题,再求解最大子序列和
在这里插入图片描述
我们将当前i~j行组成的矩阵的每一列的和存放在数组b中,其余的工作就是在求最大子序列和,并且保存其左上角和右下角

3.代码

class Solution {
public:
    vector<int> getMaxMatrix(vector<vector<int>>& matrix) {
        vector<int> res(4);
        if(matrix.empty()){
            return res;
        }
        int m = matrix.size();
        int n = matrix[0].size();

        int r1 = 0, c1 = 0;//矩阵左上角坐标
        

        int sum = 0;
        int maxSum = INT_MIN;

        for(int i = 0;i < m;++i){//子矩阵的上边
            vector<int> temp(n, 0);//二维转化为一维数组
            for(int j = i;j < m;++j){//子矩阵的下边
                sum = 0;
                for(int k = 0;k < n;++k){
                    temp[k] += matrix[j][k];
                
                    if(sum > 0){
                        sum += temp[k];
                    }
                    else{
                        sum = temp[k];
                        r1 = i;
                        c1 = k;
                    }
                    if(sum > maxSum){ //更新答案
                        maxSum = sum;
                        res[0] = r1;
                        res[1] = c1;
                        res[2] = j;
                        res[3] = k;
                    }
                }
            }
        }
        return res;
    }
};

4.复杂度分析

时间复杂度:O(mmn)
空间复杂度:O(n)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用Matlab中的FFT函数进行谐波分析,基于提供的数据,可以按照以下步骤编写程序: 1. 定义给定数据的采样频率 `fs`,根据数据中的时间间隔计算得出,即 `fs = 1 / (时间间隔)`; 2. 对输入数据进行FFT变换,使用fft函数,得到频域数据 `Y`; 3. 计算基波幅值 `fundamental`,即第一个频率分量的幅值,即 `abs(Y(1))`; 4. 计算2到11次谐波幅值 `harmonics`,即第2到11个频率分量的幅值,即 `abs(Y(2:11))`; 5. 输出结果。 下面是一个可能的Matlab程序: ``` % 定义时间间隔和数据 t = [0 0.000208333 0.000416667 0.000625 0.000833333 0.001041667 0.00125 0.001458333 0.001666667 0.001875 0.002083333 0.002291667 0.0025 0.002708333 0.002916667 0.003125 0.003333333 0.003541667 0.00375 0.003958333 0.004166667 0.004375 0.004583333 0.004791667 0.005 0.005208333 0.005416667 0.005625 0.005833333 0.006041667 0.00625 0.006458333 0.006666667 0.006875 0.007083333 0.007291667 0.0075 0.007708333 0.007916667 0.008125 0.008333333 0.008541667 0.00875 0.008958333 0.009166667 0.009375 0.009583333 0.009791667 0.01 0.010208333 0.010416667 0.010625 0.010833333 0.011041667 0.01125 0.011458333 0.011666667 0.011875 0.012083333 0.012291667 0.0125]; y = [15.92 15.68 15.52 15.04 14.6 14.08 12.96 12.24 10.96 9.76 8.28 6.8 5.56 3.24 1.72 -0.76 -3 -5.24 -6.76 -8.4 -10.24 -11.32 -12.72 -14.4 -15.2 -16.28 -16.6 -17.28 -17.44 -17.24 -17.32 -17.04 -16.84 -16.04 -15.88 -15.16 -14.08 -13.32 -12.04 -10.88 -10.16 -7.96 -6.4 -4.72 -2.36 -0.48 2.08 3.8 5.92 7.32 8.88 10.36 11.64 12.88 13.72 14.84 15.44 15.76 15.96 16.04 15.52]; % 计算采样频率 fs = 1 / (t(2) - t(1)); % 计算FFT变换 Y = fft(y); % 计算基波幅值 fundamental = abs(Y(1)); % 计算2到11次谐波幅值 harmonics = abs(Y(2:11)); % 输出结果 fprintf('基波幅值: %.2f\n', fundamental); fprintf('2到11次谐波幅值: %.2f ', harmonics); fprintf('\n'); ``` 注意:这个程序假设您提供的数据是一个完整的周期数据,如果不是一个完整的周期数据需要进行预处理,例如使用窗函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值