Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
113960 | 毛泓博(做题专用,大号Fess) | 一和零 | C++ | 通过 | 100 | 0 MS | 284 KB | 405 | 2023-12-04 20:35:05 |
#include<bits/stdc++.h> using namespace std; int x,m,n,dp[105][105]; string a[601]; int main() { cin>>x>>m>>n; for(int i=1;i<=x;i++) cin>>a[i]; for(int k=1;k<=x;k++) { int on=0,zn=0; for(int i=0;i<a[k].length();i++) { if(a[k][i]=='0') zn++; else on++; } for(int i=m;i>=zn;i--) for(int j=n;j>=on;j--) dp[i][j]=max(dp[i][j],dp[i-on][j-zn]+1); } cout<<dp[m][n] + 1; }