#define _CRT_SECURE_NO_WARNINGS #include #include #include #include #include #include #include #include #include #include #include #include #include //#include "util.h" using namespace std; typedef long long lint; typedef unsigned long long ull; typedef pair Pii; #define PI 3.14159265358979323846 #define EPS 1e-6 #define MOD ((lint)1000000007) #define MIN(a,b) ((a)<(b)?(a):(b)) #define MAX(a,b) ((a)>(b)?(a):(b)) #define FOR(i,a,b) for (int i=(a);i<(b);i++) #define RFOR(i,a,b) for (int i=(b)-1;i>=(a);i--) #define REP(i,n) for (int i=0;i<(n);i++) #define RREP(i,n) for (int i=(n)-1;i>=0;i--) template ostream& operator << (ostream& ostr, const vector<_Ty>& v) { if (v.empty()) { cout << "{ }"; return ostr; } cout << "{" << v.front(); for (auto itr = ++v.begin(); itr != v.end(); itr++) { cout << ", " << *itr; } cout << "}"; return ostr; } int countSetBits(int n) { int cnt = 0; while (n) { cnt++; n &= n - 1; } return cnt; } bool yuki0548() { string S; cin >> S; int bit = 0; bool flag = true; for (int i = 0; i < S.size(); i++) { if (S[i] < 'a' || 'm' < S[i]) { flag = false; break; } bit |= (1 << (S[i] - 'a')); } if (bit == (1 << 13) - 1) for (int i = 0; i < 13; i++) cout << (char)('a' + i) << endl; else if (countSetBits(bit) == 12) { char a = 0; while (bit & (1 << a)) a++; cout << (char)(a + 'a') << endl; } else cout << "Impossible" << endl; return 0; } int main() { //clock_t start, end; //start = clock(); yuki0548(); //end = clock(); //printf("%d msec.\n", end - start); return 0; }