rt
#include <bits/stdc++.h>
using namespace std;
#define int long long
struct node{
vector<int>v;
int x;
}dp[10010];
int n;
signed main(){
cin>>n;
for(int i=0;i<=n;i++){
dp[i].x=1;
}
for(int i=1;i<=n;i++){
for(int j=n;j>=i;j--){
if(dp[j].x<dp[j-i].x*i){
dp[j].x=dp[j-i].x*i;
dp[j].v=dp[j-i].v;
dp[j].v.push_back(i);
}
}
}
for(int i=0;i<dp[n].v.size();i++){
cout<<dp[n].v[i]<<" ";
}
cout<<"\n"<<dp[n].x;
return 0;
}