#include typedef long long ll; typedef unsigned long long ull; #define FOR(i,a,b) for(int (i)=(a);i<(b);i++) #define REP(i,n) FOR(i,0,n) #define RANGE(vec) (vec).begin(),(vec).end() using namespace std; class Yuki0010 { public: void solve(void) { int N,Total; cin>>N>>Total; vector A(N); REP(i,N) cin>>A[i]; vector> vis(N+1, vector(Total+1, false)); string ans; function dfs = [&](int s, int k, string str) { if ( s > Total ) return false; if (k == N-1) { if ( s == Total ) { ans = str; return true; } return false; } if ( vis[k][s] ) return false; vis[k][s] = true; if ( dfs(s+A[k+1], k+1, str+'+') ) return true; if ( dfs(s*A[k+1], k+1, str+'*') ) return true; return false; }; dfs(A[0], 0, ""); cout<solve(); delete obj; return 0; } #endif