zoukankan      html  css  js  c++  java
  • 环状二维数组(改进版)

    上一篇环状二维数组还存在问题,当时并未判断产生的子矩阵是否超过矩阵的范围,所以结果会出现问题。

    改进版的程序中对此进行了判断。

    此问题分为两种,一种是最大子数组成环,一种是最大子数组未成环。未成环的部分之前已实现,下面是成环部分。

    开始的思路是:将矩阵进行扩大,类似于一维数组,但是扩大后就会出现子矩阵的范围有可能超出矩阵的范围。所以在此处要有一个判断。

    改进后的程序

    #include <iostream>
    #include<time.h>
    using namespace std;
    #define max(a,b) ((a)>(b)?(a):(b))
    #define MAXN 100
    
    int A[MAXN][MAXN];
    int PartSum[MAXN][MAXN];
    
    //计算子矩阵的和
    int MatrixSum(int s, int t, int i, int j)
    {
        return PartSum[i][j] - PartSum[i][t - 1] - PartSum[s - 1][j] + PartSum[s - 1][t - 1];
    }
    
    int main()
    {
        srand((unsigned)time(NULL));
        int row, col, i, j;
        cout << "请输入二维数组的行数和列数:";
        cin >> row >> col;
        for (i = 1; i <= row; i++)
        {
            for (j = 1; j <= 2 * col - 1; j++)
            {
                for (j = 1; j <=col; j++)
                {
                    A[i][j] = rand() % 20 - 10;
                        cout << A[i][j] << " 	";
                }
                for (j = col+1; j <= 2 * col - 1; j++)
                {
                    A[i][j] = A[i][j - col];
                    cout << A[i][j] << " 	";
                }
                //cout << A[i][j] << " ";
            }
            cout<<endl;
        }
        
        for (i = 0; i <= row; i++)
            PartSum[i][0] = 0;
        for (j = 0; j <=2* col-1; j++)
            PartSum[0][j] = 0;
        // 计算矩阵的部分和
        for (i = 1; i <= row; i++)
        for (j = 1; j <= col; j++)
            PartSum[i][j] = A[i][j] + PartSum[i - 1][j] + PartSum[i][j - 1] - PartSum[i - 1][j - 1];
        int n1, n2;
        int maxsofar = A[1][1];
        for (n1 = 1; n1 <= row; n1++)
        for (n2 = n1; n2 <= row; n2++)
        {
            // 将子矩阵上下边界设为第n1行和第n2行,在这些子矩阵中取最大值,类似于一维数组求最大值
            //未成环
            int maxendinghere = MatrixSum(n1, 1, n2, 1);
            for (j = 2; j <= col-1; j++)
            {
                maxendinghere = max(MatrixSum(n1, j, n2, j), MatrixSum(n1, j, n2, j) + maxendinghere);
                maxsofar = max(maxendinghere, maxsofar);
            }
            //成环
            int sum = MatrixSum(n1, 1, n2, 1);
            int start = sum;
            int sind = 1;
            for (i = 2; i <=row; i++)
            {
                sum += MatrixSum(n1, i, n2, i);
                if (sum > start)
                {
                    start = sum;
                    sind = i;
                }
            }
            maxendinghere = MatrixSum(n1, j, n2, j);
            int tind = row;
            for (j = row - 1; j >= 1; j--)
            {
                sum += MatrixSum(n1, j, n2, j);
                if (sum > maxendinghere)
                {
                    maxendinghere = sum;
                    tind = j;
                }
            }
            if (sind<tind && start + maxendinghere>maxsofar)
            {
                maxsofar = start + maxendinghere;
            }
        }
        cout << maxsofar;
    }

  • 相关阅读:
    使用_Capistrano_进行自动化部署(2)
    使用 Capistrano 进行自动化部署
    Zend_Framework_1 框架是如何被启动的?
    PHP新版本变化
    Phpstorm 无法自动断点 Exception
    理解希尔排序
    C# Thread 线程
    Unity 依赖注入容器的AOP扩展
    C# 面向切面编程 AOP
    C# 表达式树 Expression
  • 原文地址:https://www.cnblogs.com/gting/p/4458220.html
Copyright © 2011-2022 走看看