编辑代码

public class Function {
    
    public static void main(String[] args) {
        String[] sights = {"故宫", "颐和园", "长城", "天坛"};
        int[] times = {1, 2, 3, 1};
        int[] scores = {7, 8, 9, 6};
        int days = 4;
        int[][] dp = new int[sights.length+1][days+1];
        for (int i = 1; i <= sights.length; i++) {
            for (int j = 1; j <= days; j++) {
                if (j >= times[i-1]) {
                    dp[i][j] = Math.max(dp[i-1][j], dp[i-1][j-times[i-1]] + scores[i-1]);
                } else {
                    dp[i][j] = dp[i-1][j];
                }
            }
        }
        
        int maxScore = dp[sights.length][days];
        System.out.println("最大价值为:" + maxScore);
        System.out.println("可以获得最大价值的景点是:");
        int j = days;
        for (int i = sights.length; i > 0; i--) {
            if (dp[i][j] != dp[i-1][j]) {
                System.out.println(sights[i-1] + ",时间:" + times[i-1] + "天,评分:" + scores[i-1]);
                j -= times[i-1];
            }
        }
    }
}