Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
124423 | lyq19198114514 | 健康的奶牛 | C++ | 通过 | 100 | 5 MS | 256 KB | 816 | 2024-01-23 14:29:53 |
#include<bits/stdc++.h> using namespace std; const int N=30; int n,m; int res=0x3f3f3f3f; int a[N],b[N][N],c[N],d[N]; bool pd(int x){ for(int i=0;i<n;i++){ int sum=0; for(int j=0;j<x;j++){ sum+=b[c[j]][i]; } if(sum<a[i]){ return false; } } return true; } void dfs(int cur,int idx){ if(cur==m){ if(pd(idx)){ if(idx<res){ res=idx; for(int i=0;i<idx;i++){ d[i]=c[i]+1; } } } return; } c[idx]=cur; dfs(cur+1,idx+1); dfs(cur+1,idx); } int main(){ scanf("%d",&n); for(int i=0;i<n;i++){ scanf("%d",&a[i]); } scanf("%d",&m); for(int i=0;i<m;i++){ for(int j=0;j<n;j++){ scanf("%d",&b[i][j]); } } dfs(0,0); printf("%d ",res); for(int i=0;i<res;i++){ printf("%d ",d[i]); } printf("\n"); return 0; }