洛谷 P1002 过河卒 Java实现(解法优化版本)

题目描述

在这里插入图片描述

算法思想

当前点到目标点的路径数量就是:右边的点到目标点的路径数量+下面的点到目标点的路径数量,依次类推,直到目标点。

由于我们是知道目标点位置的,所以直接从目标点开始,依次计算节点到目标节点的路径数量,赋值完成后起点(0,0)的值就是题目的解。

以下为核心代码:

public static void getPathPro(long[][] map,int aim_x,int aim_y){
   


        for(int i=aim_x;i>=0;i--){
   

            for(int j=aim_y;j>=0;j--){
   

                if(map[i][j]>=0){
   

                    if(map[i+1][j]>=0){
   
                        map[i][j]+=map[i+1][j];
                    }
                    if(map[i][j+1]>=0){
   
                        map[i][j]+=map[i][j+1];
                    }
                }
            }

        }
    }

第一步:初始化数组;

为了运行操作的一致性,在初始化数组时,若目标点为(n,m)则初始化的数组为long[n+1][m+1](由于最右边节的一列节点没有右节点,最下面一行的节点没有下面的节点)。

Scanner scanner=new Scanner(System.in);
        
        //目标点位置
        int aim_x=scanner.nextInt();
        int aim_y=scanner.nextInt();
        
        //马的位置
        int horse_x=scanner.nextInt();
        int horse_y=scanner.nextInt();

        //用于描述棋盘的数组
        long[][] map=new long[aim_x
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值