杨宇成


私信TA

用户名:dotcpp0695443

访问量:263

签 名:

瓦达西瓦sb二刺螈

等  级
排  名 844
经  验 3515
参赛次数 14
文章发表 4
年  龄 0
在职情况 学生
学  校 中山职业技术学院
专  业 大数据技术

  自我简介:

sb代言人

解题思路:

注意事项:

参考代码:

import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner sr = new Scanner(System.in);
        int n = sr.nextInt();
        int[][] dp = new int[n + 1][n + 1];
        countPaths(n, 1, dp);
        System.out.println(dp[n][1]+1);
    }
    static int countPaths(int a, int b, int[][] dp) {
        if (dp[a][b] != 0) {
            return dp[a][b]; // 如果已经计算过,直接返回结果
        }
        if (a / 2 < b) {
            return 0; // 不满足条件,返回0
        }
        int count = 1; // 至少有一个数(当前数)
        count += countPaths(a, b + 1, dp); // 递归调用1
        count += countPaths(b, 1, dp); // 递归调用2
        dp[a][b] = count; // 存储结果
        return count;
    }
}


 

0.0分

2 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区