#include <bits/stdc++.h>
#define MP make_pair
#define PB push_back
#define int long long
#define st first
#define nd second
#define rd third
#define FOR(i, a, b) for(int i =(a); i <=(b); ++i)
#define RE(i, n) FOR(i, 1, n)
#define FORD(i, a, b) for(int i = (a); i >= (b); --i)
#define REP(i, n) for(int i = 0;i <(n); ++i)
#define VAR(v, i) __typeof(i) v=(i)
#define FORE(i, c) for(VAR(i, (c).begin()); i != (c).end(); ++i)
#define ALL(x) (x).begin(), (x).end()
#define SZ(x) ((int)(x).size())
#define __builtin_ctz __builtin_ctzll
#define __builtin_clz __builtin_clzll
#define __builtin_popcount __builtin_popcountll
using namespace std;
template<typename TH> void _dbg(const char* sdbg, TH h) { cerr<<sdbg<<"="<<h<<"\n"; }
template<typename TH, typename... TA> void _dbg(const char* sdbg, TH h, TA... t) {
while(*sdbg != ',') { cerr<<*sdbg++; } cerr<<"="<<h<<","; _dbg(sdbg+1, t...);
}
#ifdef LOCAL
#define debug(...) _dbg(#__VA_ARGS__, __VA_ARGS__)
#define debugv(x) {{cerr <<#x <<" = "; FORE(itt, (x)) cerr <<*itt <<", "; cerr <<"\n"; }}
#else
#define debug(...) (__VA_ARGS__)
#define debugv(x)
#define cerr if(0)cout
#endif
#define left ____left
#define hash ____hash
typedef long long ll;
typedef long double LD;
typedef pair<int, int> PII;
typedef pair<ll, ll> PLL;
typedef vector<int> VI;
typedef vector<VI> VVI;
typedef vector<ll> VLL;
typedef vector<pair<int, int> > VPII;
typedef vector<pair<ll, ll> > VPLL;
template<class C> void mini(C&a4, C b4){a4=min(a4, b4); }
template<class C> void maxi(C&a4, C b4){a4=max(a4, b4); }
template<class T1, class T2>
ostream& operator<< (ostream &out, pair<T1, T2> pair) { return out << "(" << pair.first << ", " << pair.second << ")";}
template<class A, class B, class C> struct Triple { A first; B second; C third;
bool operator<(const Triple& t) const { if (st != t.st) return st < t.st; if (nd != t.nd) return nd < t.nd; return rd < t.rd; } };
template<class T> void ResizeVec(T&, vector<int>) {}
template<class T> void ResizeVec(vector<T>& vec, vector<int> sz) {
vec.resize(sz[0]); sz.erase(sz.begin()); if (sz.empty()) { return; }
for (T& v : vec) { ResizeVec(v, sz); }
}
typedef Triple<int, int, int> TIII;
template<class A, class B, class C>
ostream& operator<< (ostream &out, Triple<A, B, C> t) { return out << "(" << t.st << ", " << t.nd << ", " << t.rd << ")"; }
template<class T> ostream& operator<<(ostream& out, vector<T> vec) { out<<"("; for (auto& v: vec) out<<v<<", "; return out<<")"; }
template<class T> ostream& operator<<(ostream& out, set<T> vec) { out<<"("; for (auto& v: vec) out<<v<<", "; return out<<")"; }
template<class L, class R> ostream& operator<<(ostream& out, map<L, R> vec) { out<<"("; for (auto& v: vec) out<<v<<", "; return out<<")"; }
const int kInf = 1e18;
const int N = 1e6 + 5;
int a[N], b[N];
int typ[N];
int aktc, shift;
vector<int> deactivated;
int32_t main() {
ios_base::sync_with_stdio(0);
cout << fixed << setprecision(10);
cerr << fixed << setprecision(10);
cin.tie(0);
//double beg_clock = 1.0 * clock() / CLOCKS_PER_SEC;
int n, k;
cin>>n>>k;
RE (i, n) {
cin>>a[i];
}
RE (i, n) {
cin>>b[i];
}
int cnt_a = 0;
RE (i, n) {
if (a[i] < b[i]) {
cnt_a++;
typ[i] = 1;
}
}
int swapped = 0;
if (cnt_a > k) {
cnt_a = n - cnt_a;
k = n - k;
RE (i, n) {
swap(a[i], b[i]);
typ[i] = 1 - typ[i];
}
swapped = 1;
}
debug(swapped, cnt_a, k);
int lbd = 0;
int bil = 0;
RE (i, n) {
bil += min(a[i], b[i]);
maxi(bil, 0ll);
maxi(lbd, bil);
}
int need_changed = k - cnt_a;
int kl = lbd, kp = kInf, faj = kInf;
string best;
while (kl <= kp) {
aktc = (kl + kp) / 2;
shift = 0;
VI bils{0};
deactivated.clear();
string here(n + 1, 'B');
set<PII> active;
int on_set = 0;
int fail = 0;
RE (i, n) {
if (typ[i] == 1) { // moje tansze
here[i] = 'A';
shift += a[i];
} else { // jego tansze
shift += b[i];
active.insert({a[i] - b[i], i});
on_set += a[i] - b[i];
}
while (shift < 0) {
if (active.empty()) {
shift = 0;
break;
}
auto it = active.begin();
if (shift + it->st <= 0) {
deactivated.PB(it->nd);
shift += it->st;
on_set -= it->st;
active.erase(active.begin());
} else {
PII p2 = *it;
p2.st += shift;
on_set += shift;
active.erase(active.begin());
active.insert(p2);
shift = 0;
}
}
while (shift + on_set > aktc) {
if (active.empty()) {
fail = 1;
break;
}
on_set -= prev(active.end())->st;
active.erase(prev(active.end()));
}
}
for (auto p : active) {
deactivated.PB(p.nd);
}
if (!fail && SZ(deactivated) >= need_changed) {
faj = aktc;
kp = aktc - 1;
REP (i, need_changed) {
here[deactivated[i]] = 'A';
}
best = here;
} else {
kl = aktc + 1;
}
}
cout<<faj<<endl;
if (swapped) {
RE (i, n) {
best[i] = ((best[i] + 1) ^ 1) - 1;
swap(a[i], b[i]);
}
k = n - k;
}
cout<<best.substr(1)<<"\n";
#ifdef LOCAL
lbd = 0;
bil = 0;
int cnta = 0;
RE (i, n) {
if (best[i] == 'A') {
bil += a[i];
cnta++;
} else {
bil += b[i];
}
maxi(bil, 0ll);
maxi(lbd, bil);
}
assert(cnta == k);
assert(lbd == faj);
#endif
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNkZWZpbmUgTVAgbWFrZV9wYWlyCiNkZWZpbmUgUEIgcHVzaF9iYWNrCiNkZWZpbmUgaW50IGxvbmcgbG9uZwojZGVmaW5lIHN0IGZpcnN0CiNkZWZpbmUgbmQgc2Vjb25kCiNkZWZpbmUgcmQgdGhpcmQKI2RlZmluZSBGT1IoaSwgYSwgYikgZm9yKGludCBpID0oYSk7IGkgPD0oYik7ICsraSkKI2RlZmluZSBSRShpLCBuKSBGT1IoaSwgMSwgbikKI2RlZmluZSBGT1JEKGksIGEsIGIpIGZvcihpbnQgaSA9IChhKTsgaSA+PSAoYik7IC0taSkKI2RlZmluZSBSRVAoaSwgbikgZm9yKGludCBpID0gMDtpIDwobik7ICsraSkKI2RlZmluZSBWQVIodiwgaSkgX190eXBlb2YoaSkgdj0oaSkKI2RlZmluZSBGT1JFKGksIGMpIGZvcihWQVIoaSwgKGMpLmJlZ2luKCkpOyBpICE9IChjKS5lbmQoKTsgKytpKQojZGVmaW5lIEFMTCh4KSAoeCkuYmVnaW4oKSwgKHgpLmVuZCgpCiNkZWZpbmUgU1ooeCkgKChpbnQpKHgpLnNpemUoKSkKI2RlZmluZSBfX2J1aWx0aW5fY3R6IF9fYnVpbHRpbl9jdHpsbAojZGVmaW5lIF9fYnVpbHRpbl9jbHogX19idWlsdGluX2NsemxsCiNkZWZpbmUgX19idWlsdGluX3BvcGNvdW50IF9fYnVpbHRpbl9wb3Bjb3VudGxsCnVzaW5nIG5hbWVzcGFjZSBzdGQ7CnRlbXBsYXRlPHR5cGVuYW1lIFRIPiB2b2lkIF9kYmcoY29uc3QgY2hhciogc2RiZywgVEggaCkgeyBjZXJyPDxzZGJnPDwiPSI8PGg8PCJcbiI7IH0KdGVtcGxhdGU8dHlwZW5hbWUgVEgsIHR5cGVuYW1lLi4uIFRBPiB2b2lkIF9kYmcoY29uc3QgY2hhciogc2RiZywgVEggaCwgVEEuLi4gdCkgewogIHdoaWxlKCpzZGJnICE9ICcsJykgeyBjZXJyPDwqc2RiZysrOyB9IGNlcnI8PCI9Ijw8aDw8IiwiOyBfZGJnKHNkYmcrMSwgdC4uLik7Cn0KI2lmZGVmIExPQ0FMCiNkZWZpbmUgZGVidWcoLi4uKSBfZGJnKCNfX1ZBX0FSR1NfXywgX19WQV9BUkdTX18pCiNkZWZpbmUgZGVidWd2KHgpIHt7Y2VyciA8PCN4IDw8IiA9ICI7IEZPUkUoaXR0LCAoeCkpIGNlcnIgPDwqaXR0IDw8IiwgIjsgY2VyciA8PCJcbiI7IH19CiNlbHNlCiNkZWZpbmUgZGVidWcoLi4uKSAoX19WQV9BUkdTX18pCiNkZWZpbmUgZGVidWd2KHgpCiNkZWZpbmUgY2VyciBpZigwKWNvdXQKI2VuZGlmCiNkZWZpbmUgbGVmdCBfX19fbGVmdAojZGVmaW5lIGhhc2ggX19fX2hhc2gKdHlwZWRlZiBsb25nIGxvbmcgbGw7CnR5cGVkZWYgbG9uZyBkb3VibGUgTEQ7CnR5cGVkZWYgcGFpcjxpbnQsIGludD4gUElJOwp0eXBlZGVmIHBhaXI8bGwsIGxsPiBQTEw7CnR5cGVkZWYgdmVjdG9yPGludD4gVkk7CnR5cGVkZWYgdmVjdG9yPFZJPiBWVkk7CnR5cGVkZWYgdmVjdG9yPGxsPiBWTEw7CnR5cGVkZWYgdmVjdG9yPHBhaXI8aW50LCBpbnQ+ID4gVlBJSTsKdHlwZWRlZiB2ZWN0b3I8cGFpcjxsbCwgbGw+ID4gVlBMTDsKCnRlbXBsYXRlPGNsYXNzIEM+IHZvaWQgbWluaShDJmE0LCBDIGI0KXthND1taW4oYTQsIGI0KTsgfQp0ZW1wbGF0ZTxjbGFzcyBDPiB2b2lkIG1heGkoQyZhNCwgQyBiNCl7YTQ9bWF4KGE0LCBiNCk7IH0KdGVtcGxhdGU8Y2xhc3MgVDEsIGNsYXNzIFQyPgpvc3RyZWFtJiBvcGVyYXRvcjw8IChvc3RyZWFtICZvdXQsIHBhaXI8VDEsIFQyPiBwYWlyKSB7IHJldHVybiBvdXQgPDwgIigiIDw8IHBhaXIuZmlyc3QgPDwgIiwgIiA8PCBwYWlyLnNlY29uZCA8PCAiKSI7fQp0ZW1wbGF0ZTxjbGFzcyBBLCBjbGFzcyBCLCBjbGFzcyBDPiBzdHJ1Y3QgVHJpcGxlIHsgQSBmaXJzdDsgQiBzZWNvbmQ7IEMgdGhpcmQ7CiAgYm9vbCBvcGVyYXRvcjwoY29uc3QgVHJpcGxlJiB0KSBjb25zdCB7IGlmIChzdCAhPSB0LnN0KSByZXR1cm4gc3QgPCB0LnN0OyBpZiAobmQgIT0gdC5uZCkgcmV0dXJuIG5kIDwgdC5uZDsgcmV0dXJuIHJkIDwgdC5yZDsgfSB9Owp0ZW1wbGF0ZTxjbGFzcyBUPiB2b2lkIFJlc2l6ZVZlYyhUJiwgdmVjdG9yPGludD4pIHt9CnRlbXBsYXRlPGNsYXNzIFQ+IHZvaWQgUmVzaXplVmVjKHZlY3RvcjxUPiYgdmVjLCB2ZWN0b3I8aW50PiBzeikgewogIHZlYy5yZXNpemUoc3pbMF0pOyBzei5lcmFzZShzei5iZWdpbigpKTsgaWYgKHN6LmVtcHR5KCkpIHsgcmV0dXJuOyB9CiAgZm9yIChUJiB2IDogdmVjKSB7IFJlc2l6ZVZlYyh2LCBzeik7IH0KfQp0eXBlZGVmIFRyaXBsZTxpbnQsIGludCwgaW50PiBUSUlJOwp0ZW1wbGF0ZTxjbGFzcyBBLCBjbGFzcyBCLCBjbGFzcyBDPgpvc3RyZWFtJiBvcGVyYXRvcjw8IChvc3RyZWFtICZvdXQsIFRyaXBsZTxBLCBCLCBDPiB0KSB7IHJldHVybiBvdXQgPDwgIigiIDw8IHQuc3QgPDwgIiwgIiA8PCB0Lm5kIDw8ICIsICIgPDwgdC5yZCA8PCAiKSI7IH0KdGVtcGxhdGU8Y2xhc3MgVD4gb3N0cmVhbSYgb3BlcmF0b3I8PChvc3RyZWFtJiBvdXQsIHZlY3RvcjxUPiB2ZWMpIHsgb3V0PDwiKCI7IGZvciAoYXV0byYgdjogdmVjKSBvdXQ8PHY8PCIsICI7IHJldHVybiBvdXQ8PCIpIjsgfQp0ZW1wbGF0ZTxjbGFzcyBUPiBvc3RyZWFtJiBvcGVyYXRvcjw8KG9zdHJlYW0mIG91dCwgc2V0PFQ+IHZlYykgeyBvdXQ8PCIoIjsgZm9yIChhdXRvJiB2OiB2ZWMpIG91dDw8djw8IiwgIjsgcmV0dXJuIG91dDw8IikiOyB9CnRlbXBsYXRlPGNsYXNzIEwsIGNsYXNzIFI+IG9zdHJlYW0mIG9wZXJhdG9yPDwob3N0cmVhbSYgb3V0LCBtYXA8TCwgUj4gdmVjKSB7IG91dDw8IigiOyBmb3IgKGF1dG8mIHY6IHZlYykgb3V0PDx2PDwiLCAiOyByZXR1cm4gb3V0PDwiKSI7IH0KCmNvbnN0IGludCBrSW5mID0gMWUxODsKY29uc3QgaW50IE4gPSAxZTYgKyA1OwppbnQgYVtOXSwgYltOXTsKaW50IHR5cFtOXTsKaW50IGFrdGMsIHNoaWZ0Owp2ZWN0b3I8aW50PiBkZWFjdGl2YXRlZDsKaW50MzJfdCBtYWluKCkgewoKICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOwogIGNvdXQgPDwgZml4ZWQgPDwgc2V0cHJlY2lzaW9uKDEwKTsKICBjZXJyIDw8IGZpeGVkIDw8IHNldHByZWNpc2lvbigxMCk7CiAgY2luLnRpZSgwKTsKICAvL2RvdWJsZSBiZWdfY2xvY2sgPSAxLjAgKiBjbG9jaygpIC8gQ0xPQ0tTX1BFUl9TRUM7CiAgCiAgaW50IG4sIGs7CiAgY2luPj5uPj5rOwogIFJFIChpLCBuKSB7CiAgICBjaW4+PmFbaV07CiAgfQogIFJFIChpLCBuKSB7CiAgICBjaW4+PmJbaV07CiAgfQogIGludCBjbnRfYSA9IDA7CiAgUkUgKGksIG4pIHsKICAgIGlmIChhW2ldIDwgYltpXSkgewogICAgICBjbnRfYSsrOwogICAgICB0eXBbaV0gPSAxOwogICAgfQogIH0KICBpbnQgc3dhcHBlZCA9IDA7CiAgaWYgKGNudF9hID4gaykgewogICAgY250X2EgPSBuIC0gY250X2E7CiAgICBrID0gbiAtIGs7CiAgICBSRSAoaSwgbikgewogICAgICBzd2FwKGFbaV0sIGJbaV0pOwogICAgICB0eXBbaV0gPSAxIC0gdHlwW2ldOwogICAgfQogICAgc3dhcHBlZCA9IDE7CiAgfQogIGRlYnVnKHN3YXBwZWQsIGNudF9hLCBrKTsKICBpbnQgbGJkID0gMDsKICBpbnQgYmlsID0gMDsKICBSRSAoaSwgbikgewogICAgYmlsICs9IG1pbihhW2ldLCBiW2ldKTsKICAgIG1heGkoYmlsLCAwbGwpOwogICAgbWF4aShsYmQsIGJpbCk7CiAgfQogIGludCBuZWVkX2NoYW5nZWQgPSBrIC0gY250X2E7CiAgaW50IGtsID0gbGJkLCBrcCA9IGtJbmYsIGZhaiA9IGtJbmY7CiAgc3RyaW5nIGJlc3Q7CiAgd2hpbGUgKGtsIDw9IGtwKSB7CiAgICBha3RjID0gKGtsICsga3ApIC8gMjsKICAgIHNoaWZ0ID0gMDsKICAgIFZJIGJpbHN7MH07CiAgICBkZWFjdGl2YXRlZC5jbGVhcigpOwogICAgc3RyaW5nIGhlcmUobiArIDEsICdCJyk7CiAgICBzZXQ8UElJPiBhY3RpdmU7CiAgICBpbnQgb25fc2V0ID0gMDsKICAgIGludCBmYWlsID0gMDsKICAgIFJFIChpLCBuKSB7CiAgICAgIGlmICh0eXBbaV0gPT0gMSkgeyAvLyBtb2plIHRhbnN6ZQogICAgICAgIGhlcmVbaV0gPSAnQSc7CiAgICAgICAgc2hpZnQgKz0gYVtpXTsKICAgICAgfSBlbHNlIHsgLy8gamVnbyB0YW5zemUKICAgICAgICBzaGlmdCArPSBiW2ldOwogICAgICAgIGFjdGl2ZS5pbnNlcnQoe2FbaV0gLSBiW2ldLCBpfSk7CiAgICAgICAgb25fc2V0ICs9IGFbaV0gLSBiW2ldOwogICAgICB9CiAgICAgIHdoaWxlIChzaGlmdCA8IDApIHsKICAgICAgICBpZiAoYWN0aXZlLmVtcHR5KCkpIHsKICAgICAgICAgIHNoaWZ0ID0gMDsKICAgICAgICAgIGJyZWFrOwogICAgICAgIH0KICAgICAgICBhdXRvIGl0ID0gYWN0aXZlLmJlZ2luKCk7CiAgICAgICAgaWYgKHNoaWZ0ICsgaXQtPnN0IDw9IDApIHsKICAgICAgICAgIGRlYWN0aXZhdGVkLlBCKGl0LT5uZCk7CiAgICAgICAgICBzaGlmdCArPSBpdC0+c3Q7CiAgICAgICAgICBvbl9zZXQgLT0gaXQtPnN0OwogICAgICAgICAgYWN0aXZlLmVyYXNlKGFjdGl2ZS5iZWdpbigpKTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgUElJIHAyID0gKml0OwogICAgICAgICAgcDIuc3QgKz0gc2hpZnQ7CiAgICAgICAgICBvbl9zZXQgKz0gc2hpZnQ7CiAgICAgICAgICBhY3RpdmUuZXJhc2UoYWN0aXZlLmJlZ2luKCkpOwogICAgICAgICAgYWN0aXZlLmluc2VydChwMik7CiAgICAgICAgICBzaGlmdCA9IDA7CiAgICAgICAgfQogICAgICB9CiAgICAgIHdoaWxlIChzaGlmdCArIG9uX3NldCA+IGFrdGMpIHsKICAgICAgICBpZiAoYWN0aXZlLmVtcHR5KCkpIHsKICAgICAgICAgIGZhaWwgPSAxOwogICAgICAgICAgYnJlYWs7CiAgICAgICAgfQogICAgICAgIG9uX3NldCAtPSBwcmV2KGFjdGl2ZS5lbmQoKSktPnN0OwogICAgICAgIGFjdGl2ZS5lcmFzZShwcmV2KGFjdGl2ZS5lbmQoKSkpOwogICAgICB9CiAgICB9CiAgICBmb3IgKGF1dG8gcCA6IGFjdGl2ZSkgewogICAgICBkZWFjdGl2YXRlZC5QQihwLm5kKTsKICAgIH0KICAgIGlmICghZmFpbCAmJiBTWihkZWFjdGl2YXRlZCkgPj0gbmVlZF9jaGFuZ2VkKSB7CiAgICAgIGZhaiA9IGFrdGM7CiAgICAgIGtwID0gYWt0YyAtIDE7CiAgICAgIFJFUCAoaSwgbmVlZF9jaGFuZ2VkKSB7CiAgICAgICAgaGVyZVtkZWFjdGl2YXRlZFtpXV0gPSAnQSc7CiAgICAgIH0KICAgICAgYmVzdCA9IGhlcmU7CiAgICB9IGVsc2UgewogICAgICBrbCA9IGFrdGMgKyAxOwogICAgfQogIH0KICBjb3V0PDxmYWo8PGVuZGw7CiAgaWYgKHN3YXBwZWQpIHsKICAgIFJFIChpLCBuKSB7CiAgICAgIGJlc3RbaV0gPSAoKGJlc3RbaV0gKyAxKSBeIDEpIC0gMTsKICAgICAgc3dhcChhW2ldLCBiW2ldKTsKICAgIH0KICAgIGsgPSBuIC0gazsKICB9CiAgY291dDw8YmVzdC5zdWJzdHIoMSk8PCJcbiI7CiNpZmRlZiBMT0NBTAogIGxiZCA9IDA7CiAgYmlsID0gMDsKICBpbnQgY250YSA9IDA7CiAgUkUgKGksIG4pIHsKICAgIGlmIChiZXN0W2ldID09ICdBJykgewogICAgICBiaWwgKz0gYVtpXTsKICAgICAgY250YSsrOwogICAgfSBlbHNlIHsKICAgICAgYmlsICs9IGJbaV07CiAgICB9CiAgICBtYXhpKGJpbCwgMGxsKTsKICAgIG1heGkobGJkLCBiaWwpOwogIH0KICBhc3NlcnQoY250YSA9PSBrKTsKICBhc3NlcnQobGJkID09IGZhaik7CiNlbmRpZgogIAogIHJldHVybiAwOwp9Cg==