#include<iostream>
using namespace std;
int n;//货物的数量
int c;//轮船的总的载重量
int cw;//轮船当前的载重量
int r;//货物的总重量
int w[1000];//n个货物各自的重量
int x[1000];//当前最优解
int bestx[1000];//最优解
int bestw;//货物的最优载重量
void BackTrack(int s)
{if(s>n){if(cw>bestw){bestw=cw;for(int i=1;i<=n;i++)bestx[i]=x[i];}return ;}r-=w[s];if(cw+w[s]<=c){x[s]=1;cw+=w[s];BackTrack(s+1);cw-=w[s];}if(cw+r>bestw){x[s]=0;BackTrack(s+1);}r+=w[s];
}
int main()
{cout<<"轮船的总载重量:";cin>>c;cout<<"货物的数量:";cin>>n;cout<<"货物各自的重量:";for(int i=1;i<=n;i++){cin>>w[i];r+=w[i];}BackTrack(1);cout<<"货物的最优载重量:"<<bestw<<endl;cout<<"最优解:"<<endl;for(int i=1;i<=n;i++)cout<<bestx[i];cout<<endl;for(int i=1;i<=n;i++)if(bestx[i]==1)cout<<i<<" ";return 0;
}