(AC)缓存系统

题目描述

快码公司的硬盘遇到了故障!工程师克利切洛夫斯基经过排查发现,故障的原因是他们的OJ把过多的数据存储在了硬盘上,读取量太大导致硬盘发生了损坏。

为了彻底解决这个问题,公司领导决定开发一个缓存系统。缓存系统可以将一部分访问较多的数据存储在内存而不是硬盘,来减少硬盘的压力。但内存的成本相比硬盘要高很多,所以他们需要你来帮忙开发一款高效的缓存系统,既能够满足存储在内存中的数据总大小不超过内存的容量,又能够尽可能多的减少硬盘的每日读取次数。

快码公司的OJ共有N道题目(1<=N<=100),每道题目有M组不同的数据(1<=M<=100)。第i道题目的第j组数据占用的空间大小为Sij(1<=Sij<=10,000),第j组数据每日需要进行的读取次数为Aij(1<=Aij<=1,000,000,000)。你可以选择一些数据放入内存中,这些数据就不需要再占用硬盘的读取次数,但要保证所有数据要么存储在硬盘中,要么在内存中。另一个要求是,如果要把某道题目的某一组数据存储在内存中,需要保证这道题目所有编号小于这组数据的其他数据都已经存储在了内存中。

现在请你求出,在内存总容量为X的情况下(X<=5,000),硬盘每日读取次数最少是多少。

输入

本题有多组测试数据,第一行一个整数T表示测试数据的组数,1≤T≤10。

对于每组测试数据,第一行三个整数N,M,X,分别表示题目的数量、每道题目的数据组数、内存的总容量。

接下来N×M行,每M行将描述一道题目的M组数据,其中每行包含两个整数,第(i−1)×M+j行的第一个整数表示第i道题目第j组数据占用的空间大小Sij,第二个整数表示第i道题目第j组数据每日进行的读取次数Aij。

保证所有测试数据中X的和不超过10,000。

输出

每组测试数据输出一行一个整数,表示在使用内存量不超过容量的最优策略下,硬盘每日读取次数最少是多少。

样例输入 Copy
复制代码
1
2 3 10
3 4
2 5
4 7
2 4
3 6
4 8
样例输出 Copy
复制代码
15

每次循环背包忘记重置了 以及j<=m写错了写成了n

但我也是写出DP的人了!丢

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int t,n,m,x,s[109][109]{0};
ll a[101][101]{0};
int main(){
	scanf("%d",&t);
	while(t--){
		ll all=0,bag[5009]{0};
		scanf("%d%d%d",&n,&m,&x);
		for(int i=0;i<n;++i){
			for(int j=1;j<=m;++j){
				scanf("%d%lld",&s[i][j],&a[i][j]);
				all+=a[i][j];
				s[i][j]+=s[i][j-1];
				a[i][j]+=a[i][j-1];
			}
		}
		for(int i=0;i<n;++i){
			for(int k=x;k>=0;--k){
				for(int j=1;j<=m;++j){
					if(k<s[i][j])continue;
					bag[k]=max(bag[k],bag[k-s[i][j]]+a[i][j]);
				}
			}
		}
		printf("%lld\n",all-bag[x]);
	}
	return 0;
}
相关推荐
No0d1es2 小时前
电子学会青少年软件编程(C/C++)5级等级考试真题试卷(2024年6月)
c语言·c++·算法·青少年编程·电子学会·五级
大阳1234 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
如白驹过隙5 小时前
cloudflare缓存配置
前端·缓存
weixin_307779135 小时前
VS Code配置MinGW64编译GNU 科学库 (GSL)
开发语言·c++·vscode·算法
学行库小秘6 小时前
ANN神经网络回归预测模型
人工智能·python·深度学习·神经网络·算法·机器学习·回归
没落之殇6 小时前
基于C语言实现的HRV分析方法 —— 与Kubios和MATLAB对比
算法
秋难降6 小时前
线段树的深度解析(最长递增子序列类解题步骤)
数据结构·python·算法
楚韵天工6 小时前
基于GIS的无人机模拟飞行控制系统设计与实现
深度学习·算法·深度优先·无人机·广度优先·迭代加深·图搜索算法
你也向往长安城吗7 小时前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
百度智能云8 小时前
VectorDB+FastGPT一站式构建:智能知识库与企业级对话系统实战
算法