- 浏览: 54112 次
- 性别:
- 来自: 北京
文章分类
最新评论
package www.viking.com.algorithm; public class MaxSubMatrixSum { /** * @param args * * 求子矩阵的最大和 * | a11 …… a1i ……a1j ……a1n | * | a21 …… a2i ……a2j ……a2n | * | . . . . . . . | * | . . . . . . . | * | ar1 …… ari ……arj ……arn | * | . . . . . . . | * | . . . . . . . | * | ak1 …… aki ……akj ……akn | * | . . . . . . . | * | an1 …… ani ……anj ……ann | * * 基本思路: * * 假如我们知道从第i行到第j行为最大字段,那么我们把每列相加就和得到一个一维数组, * 就可以利用最大字段和的方法求解了。 * * * * */ public static void main(String[] args) { // TODO Auto-generated method stub int[][]a={ {-1,3,-3,4,2}, {2,5,-1,8,7}, {-2,3,-3,2,2}, {7,4,-2,8,3}, {2,5,-7,9,1} }; System.out.println(maxSubMatrixSum(a)); } private static int n = 5; public static int maxSubMatrixSum(int[][] a) { int maxsum = a[0][0]; int[] b = new int[n]; for (int i = 0; i < n; i++) { for (int k = 0; k < n; k++) { b[k] = 0; } for (int j = i; j < n; j++) { //b[k]记录了从i到j-1的和,累加 i到j行列的和 for (int k = 0; k < n; k++) { b[k] += a[j][k]; } int sum = maxSubQuenceSum(b); if (sum > maxsum) { maxsum = sum; } } } return maxsum; } public static int maxSubQuenceSum(int[] b) { int maxsum = b[0]; int sum = 0; for (int i = 0; i < b.length; i++) { if (sum > 0) { sum += b[i]; } else { sum = b[i]; } if (sum > maxsum) { maxsum = sum; } } return maxsum; } }
发表评论
-
查找任意两个节点的公共父节点
2011-11-04 00:42 3563基本思路是对需要查找的节点赋权值为1,其它节点权值为0.那么只 ... -
树中任意两个节点之间的距离
2011-11-04 00:28 9640树中任意两个节点之间的距离是指,从一个节点到另一个几点之间的一 ... -
用5,7,12加减运算,求最少步数得到任意数n
2011-11-03 23:59 1278package www.viking.com.algori ... -
线段重合问题
2011-11-01 13:21 2990问题:y=ax+b; 有很多线段{x0,y0,x1,y1}{ ... -
区间覆盖问题
2011-11-01 13:00 1656问题: 有很多区间,比如[1.1,3.4] [1,3] [-1 ... -
数组循环移位
2011-10-31 22:09 1444比如1 2 3 4 5 循环移位1位 ... -
最大字段和
2011-10-25 14:43 929package www.viking.com.algo ... -
有重复数的全排列
2011-10-21 18:34 8138有重复数的全排列和全排列的算法是一样的 只不过要去掉重复的序列 ... -
有重复数的组合
2011-10-21 18:33 937package com.viking.divide; ... -
无重复数组合
2011-10-21 18:30 936无重复数的组合问题 就 ... -
m n 全排列
2011-10-21 08:54 853n个字符中长度为m的全排列 public class MN ... -
子集的全排列
2011-10-21 08:51 869比如 123 1 2 3 12 21 13 31 23 32 ... -
google笔试题 人民币问题
2011-10-20 23:57 780方法一:递归方法 对 charge[]={1,5,10,20, ... -
查找无向图中的环
2011-10-19 23:51 1926static int[][] M = { { 0 ... -
无重复数的全排列问题
2011-10-18 09:51 917采用分治思想,很多书都有。。。 这里只是引用一下,因为有很几 ... -
爬台阶问题
2011-10-18 07:57 951package com.viking.dynamic; ... -
查找中间数
2011-10-18 00:21 764package com.viking.divide; ... -
整数的因子分解
2011-10-17 23:21 984package com.viking.divide; ...
相关推荐
### 最大子矩阵和问题详解 #### 一、问题背景与定义 在计算机科学与算法设计领域中,最大子矩阵和问题是寻找一个给定矩阵中具有最大和的子矩阵的问题。这类问题通常出现在数据挖掘、图像处理以及机器学习等领域,...
在计算机科学中,最大子矩阵和问题是一个经典的算法问题,主要涉及到数组处理和动态规划。在二维数组(矩阵)中,我们需要找出一个矩形子矩阵,使得其所有元素之和最大。这个问题在处理大规模数据、图像处理以及金融...
在给定的问题“11080 游泳圈的最大子矩阵和”中,我们需要解决的是在一个特定结构的二维数组中找到具有最大和的子矩阵。这个问题与经典的二维数组最大子矩阵和问题(例如, Kadane's algorithm 解决的问题)有所不同...
### 游泳圈的最大子矩阵和 #### 问题描述 在一个二维数组中,其边界条件类似于游泳圈(即数组的边缘相连),如何找到该数组中的最大子矩阵和?这里的最大子矩阵指的是所有可能的子矩阵中元素之和最大的一个。 ####...
在计算机科学领域,最大子矩阵和问题是一个经典的算法问题,主要涉及到数组处理和动态规划技术。本问题的目标是找到一个二维矩阵中的连续子矩阵,使得该子矩阵的所有元素之和最大。这个问题在实际应用中有着广泛的...
### 最大子矩阵和知识点详解 #### 一、问题背景及定义 在计算机科学与算法领域,最大子矩阵和问题是一类重要的优化问题。给定一个`M×N`的矩阵,目标是找到该矩阵中的一个子矩阵,使得该子矩阵内所有元素之和最大...
### 最大子矩阵和问题详解 #### 一、问题背景及定义 在计算机科学与算法领域,最大子矩阵和问题是一类重要的优化问题。给定一个整数矩阵 \(A\),其中 \(A\) 为 \(m \times n\) 的大小(\(m\) 行 \(n\) 列),目标...
问题:给定N×N矩阵,矩阵元素都是-127到+127之间的整数。请找到一个子矩阵,使得其元素之和最大。 输入: 第一行整数 N (N)。接下来N行元素,每行N个元素,每个元素介于-127到127之间。
3. 找到最大子矩阵和:在完成 dp 数组的填充后,最大子矩阵的和将存储在 dp 数组的最后一行最后一个元素,即 dp[m-1][n-1],其中 m 和 n 分别是矩阵的行数和列数。 4. 计算最大子矩阵的边界:为了找到最大子矩阵的...
《C++实现最大子矩阵和的暴力算法解析》 在计算机科学中,处理二维数组,尤其是矩阵的问题常常出现在算法竞赛和实际应用中。本篇文章将深入探讨如何使用C++编程语言,通过暴力搜索方法解决“最大子矩阵和”的问题。...
华为OD题分糖果猴子吃桃服务器广播和最大的子矩阵gpu耗时最大子矩阵和最大的字串计算字符串数量正方体翻面计算最短步长py3.9
// 更新最大子矩阵和 max_sum = max(max_sum, current_sum); // 如果当前和小于0,重置当前子矩阵和 if (current_sum ) current_sum = 0; } } return max_sum; } ``` 在这个代码中,我们首先获取矩阵的行数...
问题:给定1×N的单行矩阵,矩阵每个元素都是-127到+127之间的整数。请找到一个连续子矩阵,使得其元素之和最大。 输入:整数 N (N),及N个元素。
本文主要讲述了动态规划(DP)在解决最大子段和、最大子矩阵和最大子长方体问题中的应用。这些问题都是DP模型的变形,通过适当的转化和预处理,可以将高维问题转化为一维的基本问题,然后使用DP模型求解。 1. 基础...
Given an NN integer matrix (aij)NN , find the maximum value of a 1 i m N and 1 j n N . For convenience, the maximum submatrix sum is 0 if all the integers are negative. ...
通过迭代更新dp数组,我们可以计算出每个位置的最大子矩阵和,并在最后找出整个矩阵中的最大值。 此外,对于寻找最大乘积子矩阵的问题,可以使用“最大矩形”算法,如基于栈的“找最大矩形”算法。这种方法通常用于...
在计算dp[i][j]时,我们需要考虑两个子问题:不包含当前元素的最大子矩阵和(dp[i-1][j]或dp[i][j-1]),以及包含当前元素的最大子矩阵和。 以下是动态规划解法的具体步骤: 1. 初始化dp数组,通常将第一行和第一列...
标题中的“求一矩阵中子矩阵的最大和”是一个经典的计算机科学问题,通常称为“找到一个矩阵中的最大子矩阵和”。这个问题在数据结构和算法领域有着广泛的应用,特别是在处理大规模数据时寻找局部最优解的问题上。 ...