#include <bits/stdc++.h>
using namespace std;
int main() {
// your code goes here
int count=0;
vector<int>v={1,2,3,4};
make_heap(v.begin(),v.end());
for(int i=0;i<v.size();i++){
cout<<v[i]<<" ";
}
do{
if(is_heap(v.begin(),v.end())){
count=count+1;
}
}while (next_permutation(v.begin()+1,v.end()));
cout<<count;
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CnVzaW5nIG5hbWVzcGFjZSBzdGQ7CgppbnQgbWFpbigpIHsKCS8vIHlvdXIgY29kZSBnb2VzIGhlcmUKCWludCBjb3VudD0wOwoJdmVjdG9yPGludD52PXsxLDIsMyw0fTsKCW1ha2VfaGVhcCh2LmJlZ2luKCksdi5lbmQoKSk7Cglmb3IoaW50IGk9MDtpPHYuc2l6ZSgpO2krKyl7CgkJY291dDw8dltpXTw8IiAiOwoJfQoJICBkb3sKCQkJaWYoaXNfaGVhcCh2LmJlZ2luKCksdi5lbmQoKSkpewoJCQljb3VudD1jb3VudCsxOwoJCQkKCQkgICAgfQoJCSAgCgkJfXdoaWxlIChuZXh0X3Blcm11dGF0aW9uKHYuYmVnaW4oKSsxLHYuZW5kKCkpKTsKCQkKCQoJY291dDw8Y291bnQ7CgkKCXJldHVybiAwOwp9