• 二维数组的最大联通子数组和


    设计题目:求一个二维数组的连通的数组中和最大的最大值。

    设计思路:

    建立二维数组并遍历二维数组,将所有正整数分块,验证是否联通,如果不联通,判断路径。

    package demo;
    import java.util.*;
    public class Lmax {
    static Scanner scanner = new Scanner(System.in);
    public static void main(String args[]){
    int m,n;
    int b;
    Scanner scanner = new Scanner(System.in);
    System.out.println("请输入二维数组的列数:");
    m = scanner.nextInt();
    System.out.println("请输入二维数组的行数:");
    n = scanner.nextInt();
    int arr[][] = new int[n][m];
    System.out.println("请输入:");
    for(int i = 0;i<n;i++)
    for(int j=0;j<m;j++)
    {
    arr[i][j] = scanner.nextInt();
    }
    System.out.println(" ");
    b = maxArrSum(arr);
    System.out.println("最大联通数组和为"+b);
    }

    public static int[][] arrSum(int arr[][]){
    int m = arr.length;
    int n = arr[0].length;
    int p[][] = new int[m+1][n+1];
    p[0][0] = arr[0][0];
    for(int i=0; i<=m; i++) p[i][0] = 0;
    for(int i=0; i<=n; i++) p[0][i] = 0;
    for(int i=1; i<=m; i++){
    for(int j=1; j<=n; j++){
    p[i][j] = p[i-1][j] + p[i][j-1] + arr[i-1][j-1] - p[i-1][j-1];
    }
    }
    return p;
    }

    static int maxArrSum(int arr[][]){
    int m = arr.length;
    int n = arr[0].length;
    int p[][] = arrSum(arr);
    int ans = Integer.MIN_VALUE;
    for(int i=1; i<=m; i++){
    for(int j=1; j<=n; j++){
    for(int endi=i; endi <=m; endi++){
    for(int endj=j; endj<=n; endj++){
    int sum = p[endi][endj] - p[i-1][endj] - p[endi][j-1] + p[i-1][j-1];
    if(ans < sum) ans = sum;
    }
    }
    }
    }
    return ans;
    }

    }

    程序截图:

    总结:这次作业的完成,是我和张家星同学共同努力找出思路并完善程序的,实现的算法较为复杂,在我们互相的讨论下才能逐渐发掘,进行复杂问题的简单化,并成功编写。

  • 相关阅读:
    vijos 1066 弱弱的战壕 树状数组
    vijos 1057 盖房子 简单DP
    完全背包
    HDU 1203 和 HDU 2191
    dp 01背包,完全背包,多重背包 模板
    UVA11624 Fire!
    我们要学习的算法
    Find a way 两路广搜
    NYOJ 最小步数(简单深搜与广搜)
    HDU Dungeon Master广搜
  • 原文地址:https://www.cnblogs.com/ylx111/p/6680253.html
Copyright © 2020-2023  润新知