zoukankan      html  css  js  c++  java
  • 二维数组的最大联通子数组和

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

    设计思路:

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

    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;
    }

    }

    程序截图:

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

  • 相关阅读:
    [湖南集训]谈笑风生
    【SCOI2010】序列操作
    ●BZOJ 3994 [SDOI2015]约数个数和
    ●BZOJ 3309 DZY Loves Math
    ●UOJ 21 缩进优化
    ●BZOJ 2693 jzptab
    ●BZOJ 2154 Crash的数字表格
    ●BZOJ 3529 [Sdoi2014]数表
    ●2301 [HAOI2011] Problem b
    ●BZOJ 2820 YY的GCD
  • 原文地址:https://www.cnblogs.com/ylx111/p/6680253.html
Copyright © 2011-2022 走看看