AtCoder-abc262_d I Hate Non-integer Number
I Hate Non-integer Number#
dp
如果能平均分,说明选了 个数字,且其和在 的意义下为
因此考虑用 跑 次,第 次代表选择 个数字
代表前 个数字,选择 个数字,模意义下为 的个数
因此有状态转移方程
显然转移的话,对于第二维和第三维都要进行转移,因此转移复杂度为
总的算法复杂度为
我就是算出这个复杂度,然后不敢写,寄
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string>
using namespace std;
typedef long long ll;
const int maxn = 110;
const ll mod = 998244353;
ll dp[maxn][maxn][maxn];
ll a[maxn];
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
int n;
cin >> n;
for(int i=1; i<=n; i++) cin >> a[i];
ll ans = 0;
for(int i=1; i<=n; i++)
{
for(int j=0; j<=n; j++)
for(int k=0; k<=i; k++)
for(int u=0; u<i; u++)
dp[j][k][u] = 0;
for(int i=0; i<=n; i++) dp[i][0][0] = 1;
for(int j=1; j<=n; j++)
{
for(int k=i; k; k--)
{
for(int u=0; u<i; u++)
{
dp[j][k][u] = (dp[j-1][k][u] + dp[j-1][k-1][(u-a[j]%i+i)%i]) % mod;
int x = 0;
x += 1;
}
}
}
ans += dp[n][i][0];
}
cout << ans % mod << endl;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?