#include<iostream> #include<cstdio> #include<cstdlib> #include<cmath> #include<algorithm> #include<cstring> #include<cstring> #include<vector> #include<queue> #include<stack> using namespace std; int dp[25][805],path[25][805]; int n,m; int d[205],p[205],s[205],v[205]; bool select(int j,int k,int i) { while(j>0&&path[j][k]!=i) { k-=v[path[j][k]]; --j; } if(j>0)return 0; else return 1; } int main() { int cas=0; while(~scanf("%d%d",&n,&m),n&&m) { memset(dp,-1,sizeof(dp)); memset(path,0,sizeof(path)); for(int i=1; i<=n; ++i) scanf("%d%d",&p[i],&d[i]),s[i]=p[i]+d[i],v[i]=p[i]-d[i]; int fix=m*20; dp[0][fix]=0; for(int j=1; j<=m; j++) { for(int k=0; k<=2*fix; k++) { if(dp[j-1][k]>=0) { for(int i=1; i<=n; i++) if(dp[j][k+v[i]]<dp[j-1][k]+s[i]) { if(select(j-1,k,i)) { dp[j][k+v[i]]=dp[j-1][k]+s[i]; path[j][k+v[i]]=i; } } } } } int ans; for(int k=0;k<=fix;k++) if(dp[m][fix-k]>=0||dp[m][fix+k]>=0) { ans=k; break; } if(dp[m][fix-ans]>=dp[m][fix+ans])ans=fix-ans; else ans=fix+ans; printf("Jury #%d ",++cas); int c=m,psum=0,dsum=0; int res[m+1],cnt=-1; while(c>0) { res[++cnt]=path[c][ans]; psum+=p[path[c][ans]]; dsum+=d[path[c][ans]]; ans-=v[path[c][ans]]; --c; } printf("Best jury has value %d for prosecution and value %d for defence: ",psum,dsum); sort(res,res+cnt+1); for(int i=0;i<=cnt;++i) printf(" %d",res[i]); printf(" "); } return 0; }