#include <bits/stdc++.h>
#define FOR(i, a, b) for(int i = (a), _b = (b); i <= _b; ++i)
#define fi first
#define se second
#define el "\n"
#define pb push_back
#define sz(a) (int)a.size()
#define FILL(a, x) memset(a, x, sizeof(a))
using namespace std;
typedef long long ll;
typedef pair<int, int> ii;
const int N = (int)1e6 + 3;
int n, j;
ll M;
ll posArr[N + 5];
bool canJump(ll L) {
int pos = 0;
int used = 0;
while (pos < n && used < j) {
int nxt = pos;
while (nxt + 1 <= n && posArr[nxt + 1] - posArr[pos] <= L) ++nxt;
if (nxt == pos) return false;
pos = nxt;
++used;
}
return pos == n;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
freopen("river.inp", "r", stdin);
freopen("river.out", "w", stdout);
cin >> n >> M >> j;
posArr[0] = 0;
ll maxD = 0;
FOR(i, 0, n - 1) {
ll d = 1 + ( ( (ll)i * (ll)i ) % M );
posArr[i + 1] = posArr[i] + d;
if (d > maxD) maxD = d;
}
ll lo = maxD;
ll hi = posArr[n];
ll ans = hi;
while (lo <= hi) {
ll mid = (lo + hi) >> 1;
if (canJump(mid)) {
ans = mid;
hi = mid - 1;
} else {
lo = mid + 1;
}
}
cout << ans;
return 0;
}
I2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNkZWZpbmUgRk9SKGksIGEsIGIpIGZvcihpbnQgaSA9IChhKSwgX2IgPSAoYik7IGkgPD0gX2I7ICsraSkKI2RlZmluZSBmaSBmaXJzdAojZGVmaW5lIHNlIHNlY29uZAojZGVmaW5lIGVsICJcbiIKI2RlZmluZSBwYiBwdXNoX2JhY2sKI2RlZmluZSBzeihhKSAoaW50KWEuc2l6ZSgpCiNkZWZpbmUgRklMTChhLCB4KSBtZW1zZXQoYSwgeCwgc2l6ZW9mKGEpKQoKdXNpbmcgbmFtZXNwYWNlIHN0ZDsKdHlwZWRlZiBsb25nIGxvbmcgbGw7CnR5cGVkZWYgcGFpcjxpbnQsIGludD4gaWk7CmNvbnN0IGludCBOID0gKGludCkxZTYgKyAzOwoKaW50IG4sIGo7CmxsIE07CmxsIHBvc0FycltOICsgNV07Cgpib29sIGNhbkp1bXAobGwgTCkgewogICAgaW50IHBvcyA9IDA7CiAgICBpbnQgdXNlZCA9IDA7CiAgICB3aGlsZSAocG9zIDwgbiAmJiB1c2VkIDwgaikgewogICAgICAgIGludCBueHQgPSBwb3M7CiAgICAgICAgd2hpbGUgKG54dCArIDEgPD0gbiAmJiBwb3NBcnJbbnh0ICsgMV0gLSBwb3NBcnJbcG9zXSA8PSBMKSArK254dDsKICAgICAgICBpZiAobnh0ID09IHBvcykgcmV0dXJuIGZhbHNlOwogICAgICAgIHBvcyA9IG54dDsKICAgICAgICArK3VzZWQ7CiAgICB9CiAgICByZXR1cm4gcG9zID09IG47Cn0KCmludCBtYWluKCkgewogICAgaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7CiAgICBjaW4udGllKE5VTEwpOyBjb3V0LnRpZShOVUxMKTsKICAgIGZyZW9wZW4oInJpdmVyLmlucCIsICJyIiwgc3RkaW4pOwogICAgZnJlb3Blbigicml2ZXIub3V0IiwgInciLCBzdGRvdXQpOwoKICAgIGNpbiA+PiBuID4+IE0gPj4gajsKCiAgICBwb3NBcnJbMF0gPSAwOwogICAgbGwgbWF4RCA9IDA7CiAgICBGT1IoaSwgMCwgbiAtIDEpIHsKICAgICAgICBsbCBkID0gMSArICggKCAobGwpaSAqIChsbClpICkgJSBNICk7CiAgICAgICAgcG9zQXJyW2kgKyAxXSA9IHBvc0FycltpXSArIGQ7CiAgICAgICAgaWYgKGQgPiBtYXhEKSBtYXhEID0gZDsKICAgIH0KCiAgICBsbCBsbyA9IG1heEQ7CiAgICBsbCBoaSA9IHBvc0FycltuXTsKICAgIGxsIGFucyA9IGhpOwoKICAgIHdoaWxlIChsbyA8PSBoaSkgewogICAgICAgIGxsIG1pZCA9IChsbyArIGhpKSA+PiAxOwogICAgICAgIGlmIChjYW5KdW1wKG1pZCkpIHsKICAgICAgICAgICAgYW5zID0gbWlkOwogICAgICAgICAgICBoaSA9IG1pZCAtIDE7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgbG8gPSBtaWQgKyAxOwogICAgICAgIH0KICAgIH0KCiAgICBjb3V0IDw8IGFuczsKICAgIHJldHVybiAwOwp9Cg==