zoukankan      html  css  js  c++  java
  • 返回一个二维数组中最大子数组的和

    题目:返回一个二维整数数组中最大子数组的和。
    要求:
    输入一个二维整形数组,数组里有正数也有负数。
    二维数组中连续的一个子矩阵组成一个子数组,每个子数组都有一个和。
    求所有子数组的和的最大值。

    思路:先求每一行一维数组所有子数组的和的最大值,再与下面的其他行的最大值进行比较,看是否能重新生成一个新的数组,如果能,返回这个数组的和,如果不行,返回一维数组的和或求其他剩余子数组的最大值。为了方便起见,这里用3×3的数组。

    程序代码:


    #include "stdafx.h"
    #include "stdio.h"
    #include "stdlib.h"

    int _tmain(int argc, _TCHAR* argv[])
    {
    int x[3][3] = {0};
    int sum = 0;
    int max = 0;
    int i = 0;
    int j = 0;
    //赋值
    for (i = 0; i<3; i++)
    {
    for (j = 0; j<3;j++)
    {
    x[i][j] = rand()%20-10;
    printf("%d ",x[i][j] );
    }
    }
    //循环
    int M = x[0][0];
    for (i = 0; i<3; i++)
    {
    int y = i;
    do
    {
    for (j = 0; j<3; j++)
    {
    for (int u = i; u >= y; u--)
    {
    sum = sum + x[j][u];
    }
    max = max + sum;
    if (max >= M)
    {
    M =max;
    }
    if (max<0)
    {
    max = 0;
    }
    sum = 0;
    }
    y--;
    max = 0;
    } while (y >= 0);
    }
    printf(" 连续最大子数组之和:");
    printf("%d ", M);
    return 0;
    运行成果图:
    在一起编程的照片:
  • 相关阅读:
    导弹拦截版
    [USACO1.5]数字三角形 Number Triangles
    FBI树
    修复公路
    台阶问题
    阶乘问题
    连续自然数和
    又是毕业季I
    生活大爆炸版石头剪刀布
    曹冲养猪
  • 原文地址:https://www.cnblogs.com/njzy123456/p/9818371.html
Copyright © 2011-2022 走看看