赞
踩
想查看其他题的真题及题解的同学可以前往查看:CCF-CSP真题附题解大全
真题来源:矩阵运算
感兴趣的同学可以如此编码进去进行练习提交
思路讲解:
这道题也不难,使用标志数组记录耗时为i天的区域降低一天的总花费,然后从高向低降,最后就可以得出答案了。
c++满分题解:
- #include<bits/stdc++.h>
- #include<iostream>
- using namespace std;
-
- int n, k;
- long long int m;
- map<int, int>tim, res, flag;
-
- int main(){
- cin >> n >> m >> k;
-
- int max = 0;
- for(int i = 0; i < n; ++i){
- cin >> tim[i] >> res[i];
- max = max > tim[i] ? max : tim[i];
- flag[tim[i]] += res[i];
- // flag[i]为用时i天的区域缩短一天所用时
- }
- for(int i = max; i > 0; i--){
- //cout << i << " " << flag[i] << endl;
- if(max == k)break;
- if(m > flag[i]){
- m = m - flag[i];
- flag[i - 1] += flag[i];
- max--;
- }else break;
- }
- cout << max;
- return 0;
- }
运行结果:
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。