Submission #22825687
Source Code Expand
#include <bits/stdc++.h>
using namespace std;
// clang-format off
// template {{{
#define pb push_back
#define eb emplace_back
#define mp make_pair
#define f first
#define s second
#define sz(x) int((x).size())
#define all(x) (x).begin(), (x).end()
#define rall(x) (x).rbegin(), (x).rend()
#define trav(a, x) for (auto &a : x)
#define L1(u, ...) [&](auto &&u) { return __VA_ARGS__; }
#define L2(u, v, ...) [&](auto &&u, auto &&v) { return __VA_ARGS__; }
#define sort_by(x, y) sort(all(x), [&](const auto &l, const auto &r) { return y; })
using ll = long long;
using vi = vector<int>;
using vvi = vector<vi>;
using vll = vector<ll>;
using vvll = vector<vll>;
using vb = vector<bool>;
using vvb = vector<vb>;
using vd = vector<double>;
using vs = vector<string>;
using pii = pair<int, int>;
using pll = pair<ll, ll>;
using pdd = pair<double, double>;
using vpii = vector<pii>;
using vpll = vector<pll>;
using vpdd = vector<pdd>;
template <typename T> void ckmin(T &a, const T &b) { a = min(a, b); }
template <typename T> void ckmax(T &a, const T &b) { a = max(a, b); }
mt19937_64 rng(chrono::steady_clock::now().time_since_epoch().count());
namespace __input {
template <class T1, class T2> void re(pair<T1, T2> &p);
template <class T> void re(vector<T> &a);
template <class T, size_t SZ> void re(array<T, SZ> &a);
template <class T> void re(T &x) { cin >> x; }
void re(double &x) { string t; re(t); x = stod(t); }
template <class Arg, class... Args> void re(Arg &first, Args &...rest) { re(first); re(rest...); }
template <class T1, class T2> void re(pair<T1, T2> &p) { re(p.f, p.s); }
template <class T> void re(vector<T> &a) { for (int i = 0; i < sz(a); i++) re(a[i]); }
template <class T, size_t SZ> void re(array<T, SZ> &a) { for (int i = 0; i < SZ; i++) re(a[i]); }
}
using namespace __input;
namespace __output {
template <typename T> struct is_outputtable { template <typename C> static constexpr decltype(declval<ostream &>() << declval<const C &>(), bool()) test(int) { return true; } template <typename C> static constexpr bool test(...) { return false; } static constexpr bool value = test<T>(int()); };
template <class T, typename V = decltype(declval<const T &>().begin()), typename S = typename enable_if<!is_outputtable<T>::value, bool>::type> void pr(const T &x);
template <class T, typename V = decltype(declval<ostream &>() << declval<const T &>())> void pr(const T &x) { cout << x; }
template <class T1, class T2> void pr(const pair<T1, T2> &x);
template <class Arg, class... Args> void pr(const Arg &first, const Args &...rest) { pr(first); pr(rest...); }
template <class T, bool pretty = true> void prContain(const T &x) { if (pretty) pr("{"); bool fst = 1; for (const auto &a : x) pr(!fst ? pretty ? ", " : " " : "", a), fst = 0; if (pretty) pr("}"); }
template <class T> void pc(const T &x) { prContain<T, false>(x); pr("\n"); }
template <class T1, class T2> void pr(const pair<T1, T2> &x) { pr("{", x.f, ", ", x.s, "}"); }
template <class T, typename V, typename S> void pr(const T &x) { prContain(x); }
void ps() { pr("\n"); }
template <class Arg> void ps(const Arg &first) { pr(first); ps(); }
template <class Arg, class... Args> void ps(const Arg &first, const Args &...rest) { pr(first, " "); ps(rest...); }
}
using namespace __output;
#define __pn(x) pr(#x, " = ")
#ifdef ANAND_LOCAL
#define pd(...) pr("\033[1;31m"), __pn((__VA_ARGS__)), ps(__VA_ARGS__), pr("\033[0m"), cout << flush
#else
#define pd(...)
#endif
namespace __algorithm {
template <typename T> void dedup(vector<T> &v) { sort(all(v)); v.erase(unique(all(v)), v.end()); }
template <typename T> typename vector<T>::const_iterator find(const vector<T> &v, const T &x) { auto it = lower_bound(all(v), x); return it != v.end() && *it == x ? it : v.end(); }
template <typename T> size_t index(const vector<T> &v, const T &x) { auto it = find(v, x); assert(it != v.end() && *it == x); return it - v.begin(); }
template <typename I> struct _reversed_struct { I &v_; explicit _reversed_struct(I &v) : v_{v} {} typename I::reverse_iterator begin() const { return v_.rbegin(); } typename I::reverse_iterator end() const { return v_.rend(); } };
template <typename I> _reversed_struct<I> reversed(I &v) { return _reversed_struct<I>(v); }
}
using namespace __algorithm;
namespace __io {
void setIO() { ios_base::sync_with_stdio(0); cin.tie(0); cout << setprecision(15); }
}
using namespace __io;
// }}}
// clang-format on
const char A = 'a', B = 'b';
ll ncr(int n, int r) {
if (n < 0 || r < 0 || r > n)
return 0;
ll ans = 1;
for (int i = 1; i <= r; i++) {
ans *= (n + 1 - i);
ans /= i;
}
return ans;
}
int main() {
setIO();
int a, b;
ll k;
re(a, b, k);
k--;
string ans;
while (a + b > 0) {
ll count_if_a = ncr(a + b - 1, a - 1);
if (count_if_a <= k) {
k -= count_if_a;
ans += B;
b--;
} else {
ans += A;
a--;
}
}
ps(ans);
return 0;
}
Submission Info
Submission Time |
|
Task |
D - aab aba baa |
User |
AnandOza |
Language |
C++ (GCC 9.2.1) |
Score |
400 |
Code Size |
5273 Byte |
Status |
AC |
Exec Time |
6 ms |
Memory |
3628 KiB |
Judge Result
Set Name |
Sample |
All |
Score / Max Score |
0 / 0 |
400 / 400 |
Status |
|
|
Set Name |
Test Cases |
Sample |
sample_00, sample_01 |
All |
big_00, big_01, big_02, big_03, big_04, bound_00, bound_01, bound_02, bound_03, sample_00, sample_01, small_00, small_01, test_00, test_01, test_02, test_03, test_04, test_05, test_06, test_07, test_08, test_09, test_10, test_11, test_12, test_13, test_14 |
Case Name |
Status |
Exec Time |
Memory |
big_00 |
AC |
6 ms |
3548 KiB |
big_01 |
AC |
2 ms |
3420 KiB |
big_02 |
AC |
2 ms |
3468 KiB |
big_03 |
AC |
2 ms |
3420 KiB |
big_04 |
AC |
2 ms |
3592 KiB |
bound_00 |
AC |
3 ms |
3628 KiB |
bound_01 |
AC |
2 ms |
3488 KiB |
bound_02 |
AC |
2 ms |
3596 KiB |
bound_03 |
AC |
2 ms |
3540 KiB |
sample_00 |
AC |
2 ms |
3468 KiB |
sample_01 |
AC |
2 ms |
3576 KiB |
small_00 |
AC |
2 ms |
3616 KiB |
small_01 |
AC |
2 ms |
3568 KiB |
test_00 |
AC |
2 ms |
3612 KiB |
test_01 |
AC |
2 ms |
3628 KiB |
test_02 |
AC |
2 ms |
3496 KiB |
test_03 |
AC |
2 ms |
3600 KiB |
test_04 |
AC |
2 ms |
3540 KiB |
test_05 |
AC |
2 ms |
3612 KiB |
test_06 |
AC |
2 ms |
3520 KiB |
test_07 |
AC |
2 ms |
3420 KiB |
test_08 |
AC |
2 ms |
3492 KiB |
test_09 |
AC |
2 ms |
3484 KiB |
test_10 |
AC |
1 ms |
3472 KiB |
test_11 |
AC |
2 ms |
3468 KiB |
test_12 |
AC |
3 ms |
3568 KiB |
test_13 |
AC |
3 ms |
3572 KiB |
test_14 |
AC |
2 ms |
3484 KiB |