小R的蛋糕分享

小R的蛋糕分享

问题描述

小R手里有一个大小为 n 行 m 列的矩形蛋糕,每个小正方形区域都有一个代表美味度的整数。小R打算切割出一个正方形的小蛋糕给自己,而剩下的部分将给小S。她希望两人吃的部分的美味度之和尽量接近。

我们定义小R吃到的部分的美味度之和为 s_1,而小S吃到的部分的美味度之和为 s_2,请你帮助小R找到一个切割方案,使得 |s_1 - s_2| 的值最小。

测试样例

样例1:

输入:n = 3, m = 3, a = [[1, 2, 3], [2, 3, 4], [3, 2, 1]]

输出:1
样例2:

输入:n = 4, m = 4, a = [[1, 2, 3, 4], [4, 3, 2, 1], [1, 2, 3, 4], [4, 3, 2, 1]]

输出:2
样例3:

输入:n = 2, m = 2, a = [[5, 5], [5, 5]]

输出:10

题解

核心思想,枚举每一个点作为正方形右下角的那个点。使用前缀和数组进行重复求和运算。

cpp 复制代码
#include <iostream>
#include <vector>
#include <string>

using namespace std;

int solution(int n, int m, vector<vector<int>>& a) {
    // PLEASE DO NOT MODIFY THE FUNCTION SIGNATURE
    // write code here
    int sum = 0;
    // 二维前缀和,记录0,0到i,j的美味度和
    //int num[n][m+1];
    vector<vector<int>> num(n + 1, vector<int>(m + 1, 0));
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < m; j++) {
            num[i + 1][j + 1] = a[i][j] + num[i][j+1] + num[i+1][j] - num[i][j];
            sum += a[i][j];
        }
    }
    int ans = INT32_MAX;
    int maxNum = min(n, m);
    for (int i = 1; i <= maxNum; i++) {
        for (int r = 0; r < n; r++) {
            for (int c = 0; c < m; c++) {
                if (c + 1 < i  || r + 1 < i) {
                    continue;
                }
                int tmp = num[r+1][c+1] - num[r+1][c+1-i] - num[r+1-i][c+1] + num[r+1-i][c+1-i];
                ans = min(ans, abs(sum - 2 * tmp));

            }
        }
    }
    return ans;
}
相关推荐
Victory_orsh9 小时前
“自然搞懂”深度学习(基于Pytorch架构)——010203
人工智能·pytorch·python·深度学习·神经网络·算法·机器学习
CoovallyAIHub9 小时前
突破360°跟踪极限!OmniTrack++:全景MOT新范式,HOTA指标狂飙43%
深度学习·算法·计算机视觉
得物技术10 小时前
得物管理类目配置线上化:从业务痛点到技术实现
后端·算法·数据分析
CoovallyAIHub10 小时前
首个大规模、跨模态医学影像编辑数据集,Med-Banana-50K数据集专为医学AI打造(附数据集地址)
深度学习·算法·计算机视觉
熬了夜的程序员10 小时前
【LeetCode】101. 对称二叉树
算法·leetcode·链表·职场和发展·矩阵
却道天凉_好个秋11 小时前
目标检测算法与原理(二):Tensorflow实现迁移学习
算法·目标检测·tensorflow
柳鲲鹏12 小时前
RGB转换为NV12,查表式算法
linux·c语言·算法
橘颂TA12 小时前
【剑斩OFFER】算法的暴力美学——串联所有单词的字串
数据结构·算法·c/c++
Kuo-Teng12 小时前
LeetCode 73: Set Matrix Zeroes
java·算法·leetcode·职场和发展