两种方法求到一个N*M矩阵某个点的最小长度

package com.ybl.test.suanfa.java;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;

/**
 * Created by H1871 on 2018/7/19.
 */
public class Day2 {
    public static  int aa(int [][] a2) {
        int row = a2.length;//行
        int col = a2[0].length;
        for (int h = 1; h < row; h++) {
            a2[0][h] = a2[h - 1][0] + a2[h][0];
        }
        for (int k = 1; k < col; k++) {
            a2[0][k] = a2[0][k-1] + a2[0][k];
        }

        for (int l = 1; l < row; l++) {
            for (int g = 1; g < col; g++) {
                a2[l][g] = Math.min(a2[l - 1][g], a2[l][g-1])+a2[l][g];

            }
        }
        return a2[row-1][col-1];
    }
    public static void main(String[] args) {

        int[][] a2 = {
                {1, 3, 5, 9},
                {8, 1, 3, 4},
                {5, 0, 6, 1},
                {8, 8, 4, 0}
        };
        int row = a2.length;//行
        int col = a2[0].length;
        List<Integer> list = new ArrayList<Integer>();
        for (int i = 0; i < a2.length; i++) {
            int a = 0;
            for (int j = 0; j < col; j++) {
                a = a2[i][j] + a;
            }
            list.add(a);
        }
        System.out.println(Collections.min(list));
        System.out.println("=========================");

        System.out.println(aa(a2));
    }



}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值