P8663 [蓝桥杯 2018 省 A] 倍数问题 题解
5k_sync_closer · · 题解
有
证明比较显然,小于
分讨三种情况,对
然后可以得到
复杂度
#include <cstdio>
#include <algorithm>
using namespace std;
int n, k, q, f[1050][3];
int main()
{
scanf("%d%d", &n, &k);
for (int i = 0; i < k; ++i)
f[i][0] = f[i][1] = f[i][2] = -6e8;
for (int i = 1, x, y; i <= n; ++i)
{
scanf("%d", &x);
if (f[y = x % k][0] < x)
f[y][2] = f[y][1], f[y][1] = f[y][0], f[y][0] = x;
else if (f[y][1] < x)
f[y][2] = f[y][1], f[y][1] = x;
else if (f[y][2] < x)
f[y][2] = x;
}
for (int z = 0; z <= k << 1; z += k)
for (int i = 0; i < k; ++i)
for (int j = 0, p; j < k; ++j)
if ((p = z - i - j) >= 0 && p < k)
q = max(q, f[i][0] + f[j][i == j] + f[z - i - j][(i == p) + (j == p)]);
return !printf("%d", q);
}