提交时间:2024-01-23 14:29:53

运行 ID: 124423

#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; }