C. Books Queries
D. Boxes Packing
把从左至右删物品转化为从右至左加物品。模拟即可。
#include <bits/stdc++.h>
using namespace std;
const int maxn=2e5+5;
int a[maxn];
int main()
{
int n,m,k;cin>>n>>m>>k;
for(int i=1;i<=n;i++) cin>>a[i];
int cnt=m,res=0;
for(int i=n;i;i--)
{
if(res+a[i]<=k) res+=a[i];
else cnt--,res=a[i];
if(!cnt) cout<<(n-i),exit(0);
}
cout<<n;
return 0;
}
这篇文章介绍了如何通过C++编程实现一个从左到右删除物品并将剩余物品添加到背包的问题,通过模拟操作找到满足条件的最小添加次数。代码展示了如何处理整数输入并计算最优解。
661

被折叠的 条评论
为什么被折叠?



