/*
* @Author: hungeazy
* @Date: 2024-11-30 23:03:19
* @Last Modified by: hungeazy
* @Last Modified time: 2024-12-01 00:23:03
*/
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
// #pragma GCC optimize("O3")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("avx2,bmi,bmi2,popcnt,lzcnt")
using namespace std;
using namespace __gnu_pbds;
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define int long long
#define ll long long
#define ull unsigned long long
#define sz(x) x.size()
#define sqr(x) (1LL * (x) * (x))
#define all(x) x.begin(), x.end()
#define fill(f,x) memset(f,x,sizeof(f))
#define FOR(i,l,r) for(int i=l;i<=r;i++)
#define FOD(i,r,l) for(int i=r;i>=l;i--)
#define debug(x) cout << #x << " = " << x << '\n'
#define ii pair<int,int>
#define iii pair<int,ii>
#define di pair<ii,ii>
#define vi vector<int>
#define vii vector<ii>
#define mii map<int,int>
#define fi first
#define se second
#define pb push_back
#define MOD 1000000007
#define __lcm(a,b) (1ll * ((a) / __gcd((a), (b))) * (b))
#define YES cout << "YES\n"
#define NO cout << "NO\n"
#define MASK(i) (1LL << (i))
#define c_bit(i) __builtin_popcountll(i)
#define BIT(x,i) ((x) & MASK(i))
#define SET_ON(x,i) ((x) | MASK(i))
#define SET_OFF(x,i) ((x) & ~MASK(i))
#define oo 1e18
#define name "QPALIN"
#define endl '\n'
#define time() cerr << endl << "-------------Time:" << 1000.0 * clock() / CLOCKS_PER_SEC << "ms."
template<typename T> bool maximize(T &res, const T &val) { if (res < val){ res = val; return true; }; return false; }
template<typename T> bool minimize(T &res, const T &val) { if (res > val){ res = val; return true; }; return false; }
template <class T> using ordered_set = tree <T, null_type, less_equal <T>, rb_tree_tag,tree_order_statistics_node_update>;
int n,k;
string omega,t;
struct bignum {
string s;
bignum() {
this->s = "0";
}
bignum(string a) {
s = a;
}
bignum(int a) {
s = to_string(a);
}
friend istream &operator>>(istream &is, bignum &a) {
is >> a.s;
return is;
}
friend ostream &operator<<(ostream &os, const bignum &a) {
os << a.s;
return os;
}
bool operator<(const bignum &a) const {
if (sz(s) < sz(a.s)) return 1;
if (sz(s) > sz(a.s)) return 0;
return s < a.s;
}
bool operator>(const bignum &a) const {
if (sz(s) > sz(a.s)) return 1;
if (sz(s) < sz(a.s)) return 0;
return s > a.s;
}
bool operator==(const bignum &a) {
return s == a.s;
}
bool operator!=(const bignum &a) {
return s != a.s;
}
bool operator<=(const bignum &a) {
if (sz(s) < sz(a.s)) return 1;
if (sz(s) > sz(a.s)) return 0;
return s <= a.s;
}
bool operator>=(const bignum &a) {
if (sz(s) > sz(a.s)) return 1;
if (sz(s) < sz(a.s)) return 0;
return s >= a.s;
}
bignum operator+(const bignum &a) {
string x = "";
int m = s.size(), n = a.s.size();
int d = abs(m-n), c = 0;
FOD(i,min(n,m)-1,0)
{
int sum = c;
if (m < n) sum += s[i]-'0'+a.s[i+d]-'0';
else sum += s[i+d]-'0'+a.s[i]-'0';
x += sum%10+'0';
c = sum/10;
}
if (m < n)
FOD(i,n-m-1,0)
{
int sum = ((a.s[i]-'0')+c);
x += sum%10+'0';
c = sum/10;
}
else
FOD(i,m-n-1,0)
{
int sum = ((s[i] - '0') + c);
x += sum%10+'0';
c = sum/10;
}
if (c) x += c+'0';
while (x.size() > 1 and x.back() == '0') x.pop_back();
reverse(all(x));
return bignum(x);
}
bignum operator-(const bignum &a) {
string x = "";
int m = s.size(), n = a.s.size();
int d = m-n, c = 0;
FOD(i,n-1,0)
{
int sub = ((s[i+d]-'0')-(a.s[i]-'0')-c);
if (sub < 0)
{
sub += 10;
c = 1;
}
else c = 0;
x += sub+'0';
}
FOD(i,m-n-1,0)
{
if (s[i] == '0' and c)
{
x += '9';
continue;
}
int sub = ((s[i]-'0')-c);
if (i > 0 or sub > 0) x += sub + '0';
c = 0;
}
while (x.size() > 1 and x.back() == '0') x.pop_back();
reverse(all(x));
return bignum(x);
}
bignum operator*(const bignum &a) {
int m = s.size(), n = a.s.size();
string x(m+n, '0');
int p = 0;
FOD(i,m-1,0)
{
int c = 0, q = 0;
FOD(j,n-1,0)
{
int sum = (s[i]-'0')*(a.s[j]-'0')+x[p+q]-'0'+c;
x[p+q] = sum%10+'0';
c = sum/10;
++q;
}
if (c > 0) x[p+q] += c;
++p;
}
while (x.size() > 1 and x.back() == '0') x.pop_back();
reverse(all(x));
return bignum(x);
}
};
namespace sub1 {
bool a[MASK(10)];
int cnt[2];
bool approved()
{
vector<char> vec;
for (char c : omega) vec.pb(c);
sort(all(vec));
vec.erase(unique(all(vec)),vec.end());
return n <= 10 and vec[0] == 'a' and vec[1] == 'b';
}
bool cmp(int x, int y)
{
FOR(i,0,n-1)
{
if ((BIT(x,i)) < (BIT(y,i))) return true;
if ((BIT(x,i)) > (BIT(y,i))) return false;
}
return false;
}
void solve(void)
{
FOR(mask,0,MASK(n)-1)
if (c_bit(mask) == k)
{
if (BIT(mask,0) or BIT(mask,n-1)) continue;
FOR(i,0,MASK(n)-1)
{
if (a[i]) continue;
cnt[0] = cnt[1] = 0;
a[i] = true;
FOR(j,0,n-1)
{
bool cur = BIT(i,j);
++cnt[cur];
if (BIT(mask,j))
{
if ((cnt[0]&1) and (cnt[1]&1))
{
a[i] = false;
break;
}
}
}
if ((cnt[0]&1) and (cnt[1]&1)) a[i] = false;
}
}
vi v;
FOD(i,MASK(n)-1,0)
if (a[i]) v.pb(i);
sort(all(v),cmp);
stringstream geek;
geek << t;
int x;
geek >> x;
FOR(i,0,n-1)
{
bool cnt = BIT(v[x-1],i);
cout << char('a'+cnt);
}
}
}
namespace sub2 {
int dp[12][10][1100];
vector<char> vec;
bool approved()
{
return n <= 10 and !k;
}
int ok(int x)
{
int ans = 0;
while (x) ans += x%2, x /= 2;
return ans;
}
void calc(int pos, int last, int state)
{
int &ans = dp[pos][last][state];
if (pos > n)
{
ans = (ok(state) <= 1);
return;
}
if (ans != -1) return;
ans = 0;
FOR(j,0,vec.size()-1)
{
calc(pos+1,j,state^MASK(j));
ans += dp[pos+1][j][state^MASK(j)];
}
}
void solve(void)
{
fill(dp,-1);
for (char c : omega) vec.pb(c);
sort(all(vec));
vec.erase(unique(all(vec)),vec.end());
calc(1,0,0);
stringstream geek;
geek << t;
int x;
geek >> x;
int state = 0;
FOR(i,1,n)
FOR(j,0,vec.size()-1)
if (dp[i+1][j][state^MASK(j)] < x)
x -= dp[i+1][j][state^MASK(j)];
else
{
cout << vec[j];
state ^= MASK(j);
break;
}
}
}
namespace sub3 {
bool approved()
{
vector<char> vec;
for (char c : omega) vec.pb(c);
sort(all(vec));
vec.erase(unique(all(vec)),vec.end());
return n <= 50 and !k and vec[0] == 'a' and vec[1] == 'b';
}
void solve(void)
{
stringstream geek;
geek << t;
int x;
geek >> x;
if (n&1)
{
x--;
FOD(i,n-1,0)
{
bool cur = BIT(x,i);
cout << char('a'+cur);
}
return;
}
int cnt = 0;
FOD(i,n-1,1)
{
if (x > MASK(i-1))
{
x -= MASK(i-1);
cout << 'b';
++cnt;
}
else cout << 'a';
}
cout << (cnt&1?'b':'a');
}
}
namespace sub4 {
bignum dp[52][6][MASK(5)];
int len;
bool approved()
{
return n <= 50 and !k;
}
int ok(int x)
{
int ans = 0;
while (x) ans += x%2, x /= 2;
return ans;
}
void calc(int pos, int last, int state)
{
auto &ans = dp[pos][last][state];
if (pos > n)
{
ans = bignum(ok(state) <= 1?"1":"0");
return;
}
if (ans != bignum("-1")) return;
ans = bignum("0");
FOR(j,0,len-1)
{
calc(pos+1,j,state^MASK(j));
ans = ans+dp[pos+1][j][state^MASK(j)];
}
}
void solve(void)
{
vector<char> vec;
for (char c : omega) vec.pb(c);
sort(all(vec));
vec.erase(unique(all(vec)),vec.end());
len = vec.size();
FOR(i,0,n)
FOR(j,0,len)
FOR(mask,0,MASK(len)-1) dp[i][j][mask] = bignum("-1");
calc(1,0,0);
bignum x = bignum(t);
int state = 0;
FOR(i,1,n)
FOR(j,0,len-1)
if (dp[i+1][j][state^MASK(j)] < x)
x = x-dp[i+1][j][state^MASK(j)];
else
{
cout << vec[j];
state ^= MASK(j);
break;
}
}
}
namespace sub5 {
bignum dp[52][6][52][MASK(5)];
int len;
int ok(int x)
{
int ans = 0;
while (x) ans += x%2, x /= 2;
return ans;
}
void calc(int pos, int last, int level, int state)
{
auto &ans = dp[pos][last][level][state];
if (pos > n)
{
ans = bignum(ok(state) <= 1 and level >= k+2?"1":"0");
return;
}
if (ans != bignum("-1")) return;
ans = bignum("0");
FOR(j,0,len-1)
{
calc(pos+1,j,level+(ok(state^MASK(j)) <= 1),state^MASK(j));
ans = ans+dp[pos+1][j][level+(ok(state^MASK(j)) <= 1)][state^MASK(j)];
}
}
void solve(void)
{
vector<char> vec;
for (char c : omega) vec.pb(c);
sort(all(vec));
vec.erase(unique(all(vec)),vec.end());
len = vec.size();
FOR(i,0,n)
FOR(j,0,len)
FOR(cur,0,n)
FOR(mask,0,MASK(len)-1) dp[i][j][cur][mask] = bignum("-1");
calc(1,0,0,0);
bignum x = bignum(t);
int state = 0, level = 0;
FOR(i,1,n)
FOR(j,0,len-1)
if (dp[i+1][j][level+(ok(state^MASK(j)) <= 1)][state^MASK(j)] < x)
x = x-dp[i+1][j][level+(ok(state^MASK(j)) <= 1)][state^MASK(j)];
else
{
cout << vec[j];
state ^= MASK(j);
level += (ok(state) <= 1);
break;
}
}
}
signed main()
{
fast;
if (fopen(name".inp","r"))
{
freopen(name".inp","r",stdin);
freopen(name".out","w",stdout);
}
cin >> n >> k >> omega >> t;
// if (sub1::approved()) return sub1::solve(), time(), 0;
// if (sub2::approved()) return sub2::solve(), time(), 0;
// if (sub3::approved()) return sub3::solve(), time(), 0;
// if (sub4::approved()) return sub4::solve(), time(), 0;
sub5::solve();
time();
return 0;
}
// ██░ ██ █ ██ ███▄ █ ▄████
//▓██░ ██▒ ██ ▓██▒ ██ ▀█ █ ██▒ ▀█▒
//▒██▀▀██░▓██ ▒██░▓██ ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█ ░██░▓██▒ ▐▌██▒░▓█ ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░ ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░ ▒ ▒ ░▒ ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░ ░ ▒░ ░ ░
// ░ ░░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░
// ░ ░ ░ ░ ░ ░
/*
* @Author: hungeazy
* @Date:   2024-11-30 23:03:19
* @Last Modified by:   hungeazy
* @Last Modified time: 2024-12-01 00:23:03
*/
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp> 
#include <ext/pb_ds/tree_policy.hpp> 
// #pragma GCC optimize("O3")  
// #pragma GCC optimize("unroll-loops")  
// #pragma GCC target("avx2,bmi,bmi2,popcnt,lzcnt")  
using namespace std;
using namespace __gnu_pbds; 
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define int long long
#define ll long long 
#define ull unsigned long long
#define sz(x) x.size()
#define sqr(x) (1LL * (x) * (x))
#define all(x) x.begin(), x.end()
#define fill(f,x) memset(f,x,sizeof(f))
#define FOR(i,l,r) for(int i=l;i<=r;i++)
#define FOD(i,r,l) for(int i=r;i>=l;i--)
#define debug(x) cout << #x << " = " << x << '\n'
#define ii pair<int,int>
#define iii pair<int,ii>
#define di pair<ii,ii>
#define vi vector<int>
#define vii vector<ii>
#define mii map<int,int>
#define fi first
#define se second
#define pb push_back
#define MOD 1000000007
#define __lcm(a,b) (1ll * ((a) / __gcd((a), (b))) * (b))
#define YES cout << "YES\n"
#define NO cout << "NO\n"
#define MASK(i) (1LL << (i))
#define c_bit(i) __builtin_popcountll(i)
#define BIT(x,i) ((x) & MASK(i))
#define SET_ON(x,i) ((x) | MASK(i))
#define SET_OFF(x,i) ((x) & ~MASK(i))
#define oo 1e18
#define name "QPALIN"
#define endl '\n'
#define time() cerr << endl << "-------------Time:" << 1000.0 * clock() / CLOCKS_PER_SEC << "ms."
template<typename T> bool maximize(T &res, const T &val) { if (res < val){ res = val; return true; }; return false; }
template<typename T> bool minimize(T &res, const T &val) { if (res > val){ res = val; return true; }; return false; }
template <class T> using ordered_set = tree <T, null_type, less_equal <T>, rb_tree_tag,tree_order_statistics_node_update>;
int n,k;
string omega,t;

struct bignum {

    string s;

    bignum() {
        this->s = "0";
    }

    bignum(string a) {
        s = a;
    }

    bignum(int a) {
        s = to_string(a);
    }

    friend istream &operator>>(istream &is, bignum &a) {
        is >> a.s;
        return is;
    }

    friend ostream &operator<<(ostream &os, const bignum &a) {
        os << a.s;
        return os;
    }

    bool operator<(const bignum &a) const {
        if (sz(s) < sz(a.s)) return 1;
        if (sz(s) > sz(a.s)) return 0;
        return s < a.s;
    }

    bool operator>(const bignum &a) const {
        if (sz(s) > sz(a.s)) return 1;
        if (sz(s) < sz(a.s)) return 0;
        return s > a.s;
    }

    bool operator==(const bignum &a) {
        return s == a.s;
    }

    bool operator!=(const bignum &a) {
        return s != a.s;
    }

    bool operator<=(const bignum &a) {
        if (sz(s) < sz(a.s)) return 1;
        if (sz(s) > sz(a.s)) return 0;
        return s <= a.s;
    }

    bool operator>=(const bignum &a) {
        if (sz(s) > sz(a.s)) return 1;
        if (sz(s) < sz(a.s)) return 0;
        return s >= a.s;
    }

    bignum operator+(const bignum &a) {
        string x = "";
        int m = s.size(), n = a.s.size();
        int d = abs(m-n), c = 0;
        FOD(i,min(n,m)-1,0) 
        {
            int sum = c;
            if (m < n) sum += s[i]-'0'+a.s[i+d]-'0';
            else sum += s[i+d]-'0'+a.s[i]-'0';
            x += sum%10+'0';
            c = sum/10;
        }
        if (m < n) 
            FOD(i,n-m-1,0) 
        	{
                int sum = ((a.s[i]-'0')+c);
                x += sum%10+'0';
                c = sum/10;
            }
        else 
            FOD(i,m-n-1,0) 
            {
                int sum = ((s[i] - '0') + c);
                x += sum%10+'0';
                c = sum/10;
            }
        if (c) x += c+'0';
        while (x.size() > 1 and x.back() == '0') x.pop_back();
        reverse(all(x));
        return bignum(x);
    }

    bignum operator-(const bignum &a) {
        string x = "";
        int m = s.size(), n = a.s.size();
        int d = m-n, c = 0;
        FOD(i,n-1,0)
        {
            int sub = ((s[i+d]-'0')-(a.s[i]-'0')-c);
            if (sub < 0) 
            {
                sub += 10;
                c = 1;
            } 
            else c = 0;
            x += sub+'0';
        }
        FOD(i,m-n-1,0) 
        {
            if (s[i] == '0' and c) 
            {
                x += '9';
                continue;
            }
            int sub = ((s[i]-'0')-c);
            if (i > 0 or sub > 0) x += sub + '0';
            c = 0;
        }
        while (x.size() > 1 and x.back() == '0') x.pop_back();
        reverse(all(x));
        return bignum(x);
    }

    bignum operator*(const bignum &a) {
        int m = s.size(), n = a.s.size();
        string x(m+n, '0');
        int p = 0;
        FOD(i,m-1,0) 
        {
            int c = 0, q = 0;
            FOD(j,n-1,0) 
            {
                int sum = (s[i]-'0')*(a.s[j]-'0')+x[p+q]-'0'+c;
                x[p+q] = sum%10+'0';
                c = sum/10;
                ++q;
            }
            if (c > 0) x[p+q] += c;
            ++p;
        }
        while (x.size() > 1 and x.back() == '0') x.pop_back();
        reverse(all(x));
        return bignum(x);
    }
};

namespace sub1 {

	bool a[MASK(10)];
	int cnt[2];

	bool approved()
	{
		vector<char> vec;
		for (char c : omega) vec.pb(c);
		sort(all(vec));
		vec.erase(unique(all(vec)),vec.end());
		return n <= 10 and vec[0] == 'a' and vec[1] == 'b';
	}

	bool cmp(int x, int y)
	{
		FOR(i,0,n-1)
		{
			if ((BIT(x,i)) < (BIT(y,i))) return true;
			if ((BIT(x,i)) > (BIT(y,i))) return false;
		}
		return false;
	}

	void solve(void)
	{
		FOR(mask,0,MASK(n)-1)
			if (c_bit(mask) == k)
			{
				if (BIT(mask,0) or BIT(mask,n-1)) continue;
				FOR(i,0,MASK(n)-1)
				{
					if (a[i]) continue;
					cnt[0] = cnt[1] = 0;
					a[i] = true;
					FOR(j,0,n-1)
					{
						bool cur = BIT(i,j);
						++cnt[cur];
						if (BIT(mask,j))
						{
							if ((cnt[0]&1) and (cnt[1]&1))
							{
								a[i] = false;
								break;
							}
						}
					}
					if ((cnt[0]&1) and (cnt[1]&1)) a[i] = false;
				}
			}
		vi v;
		FOD(i,MASK(n)-1,0)
			if (a[i]) v.pb(i);
		sort(all(v),cmp);
		stringstream geek;
		geek << t;
		int x;
		geek >> x;
		FOR(i,0,n-1) 
		{
			bool cnt = BIT(v[x-1],i);
			cout << char('a'+cnt);
		}
	}

}

namespace sub2 {

	int dp[12][10][1100];
	vector<char> vec;

	bool approved()
	{
		return n <= 10 and !k;
	}

	int ok(int x)
	{
		int ans = 0;
		while (x) ans += x%2, x /= 2;
		return ans;
	}

	void calc(int pos, int last, int state)
	{
		int &ans = dp[pos][last][state];
		if (pos > n) 
		{
			ans = (ok(state) <= 1);
			return;
		}
		if (ans != -1) return;
		ans = 0;
		FOR(j,0,vec.size()-1) 
		{
			calc(pos+1,j,state^MASK(j));
			ans += dp[pos+1][j][state^MASK(j)];
		}
	}

	void solve(void)
	{
		fill(dp,-1);
		for (char c : omega) vec.pb(c);
		sort(all(vec));
		vec.erase(unique(all(vec)),vec.end());
		calc(1,0,0);
		stringstream geek;
		geek << t;
		int x;
		geek >> x;	
		int state = 0;
		FOR(i,1,n)
			FOR(j,0,vec.size()-1)
				if (dp[i+1][j][state^MASK(j)] < x) 
					x -= dp[i+1][j][state^MASK(j)];
				else 
				{
					cout << vec[j];
					state ^= MASK(j);
					break;
				}
	}
	
}

namespace sub3 {

	bool approved()
	{
		vector<char> vec;
		for (char c : omega) vec.pb(c);
		sort(all(vec));
		vec.erase(unique(all(vec)),vec.end());
		return n <= 50 and !k and vec[0] == 'a' and vec[1] == 'b';
	}

	void solve(void)
	{
		stringstream geek;
		geek << t;
		int x;
		geek >> x;
		if (n&1)
		{
			x--;
			FOD(i,n-1,0) 
			{
				bool cur = BIT(x,i);
				cout << char('a'+cur);
			}
			return;
		}
		int cnt = 0;
		FOD(i,n-1,1)
		{
			if (x > MASK(i-1)) 
			{
				x -= MASK(i-1);
				cout << 'b';
				++cnt;
			}
			else cout << 'a';
		}
		cout << (cnt&1?'b':'a');
	}

}

namespace sub4 {

	bignum dp[52][6][MASK(5)];
	int len;

	bool approved()
	{
		return n <= 50 and !k;
	}

	int ok(int x)
	{
		int ans = 0;
		while (x) ans += x%2, x /= 2;
		return ans;
	}

	void calc(int pos, int last, int state)
	{
		auto &ans = dp[pos][last][state];
		if (pos > n) 
		{
			ans = bignum(ok(state) <= 1?"1":"0");
			return;
		}
		if (ans != bignum("-1")) return;
		ans = bignum("0");
		FOR(j,0,len-1) 
		{
			calc(pos+1,j,state^MASK(j));
			ans = ans+dp[pos+1][j][state^MASK(j)];
		}
	}

	void solve(void)
	{
		vector<char> vec;
		for (char c : omega) vec.pb(c);
		sort(all(vec));
		vec.erase(unique(all(vec)),vec.end());
		len = vec.size();
		FOR(i,0,n)
			FOR(j,0,len)
				FOR(mask,0,MASK(len)-1) dp[i][j][mask] = bignum("-1");
		calc(1,0,0);
		bignum x = bignum(t);	
		int state = 0;
		FOR(i,1,n)
			FOR(j,0,len-1)
				if (dp[i+1][j][state^MASK(j)] < x) 
					x = x-dp[i+1][j][state^MASK(j)];
				else 
				{
					cout << vec[j];
					state ^= MASK(j);
					break;
				}
	}	

}

namespace sub5 {

	bignum dp[52][6][52][MASK(5)];
	int len;

	int ok(int x)
	{
		int ans = 0;
		while (x) ans += x%2, x /= 2;
		return ans;
	}

	void calc(int pos, int last, int level, int state)
	{
		auto &ans = dp[pos][last][level][state];
		if (pos > n) 
		{
			ans = bignum(ok(state) <= 1 and level >= k+2?"1":"0");
			return;
		}
		if (ans != bignum("-1")) return;
		ans = bignum("0");
		FOR(j,0,len-1) 
		{
			calc(pos+1,j,level+(ok(state^MASK(j)) <= 1),state^MASK(j));
			ans = ans+dp[pos+1][j][level+(ok(state^MASK(j)) <= 1)][state^MASK(j)];
		}
	}

	void solve(void)
	{
		vector<char> vec;
		for (char c : omega) vec.pb(c);
		sort(all(vec));
		vec.erase(unique(all(vec)),vec.end());
		len = vec.size();
		FOR(i,0,n)
			FOR(j,0,len)
				FOR(cur,0,n)
					FOR(mask,0,MASK(len)-1) dp[i][j][cur][mask] = bignum("-1");
		calc(1,0,0,0);
		bignum x = bignum(t);	
		int state = 0, level = 0;
		FOR(i,1,n)
			FOR(j,0,len-1)
				if (dp[i+1][j][level+(ok(state^MASK(j)) <= 1)][state^MASK(j)] < x) 
					x = x-dp[i+1][j][level+(ok(state^MASK(j)) <= 1)][state^MASK(j)];
				else 
				{
					cout << vec[j];
					state ^= MASK(j);
					level += (ok(state) <= 1);
					break;
				}
	}	

}

signed main()
{
    fast;
    if (fopen(name".inp","r"))
    {
    	freopen(name".inp","r",stdin);
    	freopen(name".out","w",stdout);
    }
    cin >> n >> k >> omega >> t;
    // if (sub1::approved()) return sub1::solve(), time(), 0;
    // if (sub2::approved()) return sub2::solve(), time(), 0;
    // if (sub3::approved()) return sub3::solve(), time(), 0;
    // if (sub4::approved()) return sub4::solve(), time(), 0;
    sub5::solve();
    time();
    return 0;
}
// ██░ ██  █    ██  ███▄    █   ▄████
//▓██░ ██▒ ██  ▓██▒ ██ ▀█   █  ██▒ ▀█▒
//▒██▀▀██░▓██  ▒██░▓██  ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█  ░██░▓██▒  ▐▌██▒░▓█  ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░   ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░   ▒ ▒  ░▒   ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░   ░ ▒░  ░   ░
// ░  ░░ ░ ░░░ ░ ░    ░   ░ ░ ░ ░   ░
// ░  ░  ░   ░              ░       ░
