🕌
ARC 102 | C - Triangular Relationship
問題
解法
問題文より以下である。
ここで
対称性より
上記を利用し、
ここで
対称性より
よって
または
コード
#include <bits/stdc++.h>
#include <atcoder/all>
using namespace std;
using namespace atcoder;
using ll = long long;
using ld = long double;
using uint = unsigned int;
using ull = unsigned long long;
const int MOD = 1e9 + 7;
int main() {
ll n, k;
cin >> n >> k;
vector<ll> v(k);
for (int i = 1; i <= n; i++) {
v[i % k]++;
}
if (k % 2 == 0) {
cout << v[0] * v[0] * v[0] + v[k / 2] * v[k / 2] * v[k / 2] << endl;
} else {
cout << v[0] * v[0] * v[0] << endl;
}
}
参考
Discussion