#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; int main() { long i, j; int k; cin >> k; for (i = 2; i <= 30; i++) { long num = 0; for (int h = i - 1; h >= 1; h--) { num += h; } if (num == k) { for (i; i > 0; j--) { cout << 1; if (i - 1 != 0) { cout << " "; } else { cout << endl; } } getchar(); getchar(); return 0; } for (j = 1; j <= 30 - i; j++) { //long num2 = j*i + i; long num2 = ( pow(2,j)-1) * num + num; //cout << "num2->" << num2 << endl; //cout << "j->" << j << " i->" << i << endl << endl; if (num2 == k) { cout << j + i << endl; for (int jj = 0; jj < j; jj++) { cout << 0 << " "; } for (int jj = 0; jj < i; jj++) { cout << 1; if (jj + 1 != i) { cout << " "; } else { cout << endl; } } getchar(); getchar(); return 0; } } } getchar(); getchar(); return 0; }