解题思路:

注意事项:

参考代码:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.StreamTokenizer;
import java.util.ArrayList;

public class Main {
    static StreamTokenizer cin = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
    static int month[] = new int[] { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
    static int n, m, k;
    static int fen[][] = new int[400][1010];//把票据分组,由于不是闰年,那么可知一共有365天,即分成365组
    static int f[][] = new int[400][5010];//表示前i天中选,是否存在报销价格为j的方案,1表示存在,0表示不存在
    static int st[] =new int[5010];//标记记录报销金额为j时,最先在哪一天出现
    static int len[] = new int[400];//记录365个分组,,每个分组有多少张票据
    static int sum(int x) {//
        int res = 0;
        for (int i = 1; i <= x; i++) {
            res += month[i];
        }
        return res;
    }
    static int nextInt() throws IOException {
        cin.nextToken();
        return (int) cin.nval;
    }
    public static void main(String[] args) throws IOException {
        n = nextInt();
        m = nextInt();
        k = nextInt();
        int a, b, c;
        for (int i = 1; i <= n; i++) {
            a = nextInt();
            b = nextInt();
            c = nextInt();
            int idx = sum(a - 1) + b;//把月份+天数转化为365天格式的编号
            fen[idx][++len[idx]] = c;
            f[idx][c]=1;
        }
        f[0][0]=1;
        for(int i=0;i<5010;i++) st[i]=1000000;
        int maxv = 0;
        st[0]=0;
        for (int i = 1; i <=365; i++) {//枚举分组
            for (int t = 1; t <= len[i]; t++) {//枚举该分组的票据
                int x = fen[i][t];//x表示当前票据的报销金额
                for (int j = m; j >= 0; j--) {
                    if (j >= x&&st[j-x]<=Math.max(0,i-k)) {//如果st[j-x]最早出现的位置小于等于i-k天,那么j就是合法的
                        f[i][j]=1;
                    }
                    if (f[i][j] > 0) {
                        st[j]=Math.min(st[j], i);
                        maxv = Math.max(maxv, j);
                       }
                }
            }
        }
        System.out.println(maxv);
    }
}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论