#include #define int long long #define inf 0x3f3f3f3f3f3f3f3f using namespace std; int n,a[22],ans=-inf,now; char symb[22]; void dfs(int k){ if(k>n){ now=a[1]; for(int i=2;i<=n;i++){ if(symb[i]=='+')now+=a[i]; else if(symb[i]=='-')now-=a[i]; else if(symb[i]=='*')now*=a[i]; else now/=a[i]; } ans=max(ans,now); return; } if(a[k]>0){ symb[k]='+'; dfs(k+1); symb[k]='*'; dfs(k+1); symb[k]='/'; dfs(k+1); } else if(a[k]<0){ symb[k]='-'; dfs(k+1); symb[k]='*'; dfs(k+1); symb[k]='/'; dfs(k+1); } else{ symb[k]='+'; dfs(k+1); symb[k]='*'; dfs(k+1); } return; } signed main(){ scanf("%lld",&n); for(int i=1;i<=n;i++)scanf("%lld",&a[i]); dfs(2); printf("%lld\n",ans); return 0; }