P4980 Pólya 定理 + DFS

58 篇文章 0 订阅
题意

传送门 P4980 【模板】Pólya 定理

题解

根据 Pólya 定理,本质不同的染色方案数为
1 n ∑ k = 0 n − 1 n g c d ( n , k ) \frac{1}{n}\sum\limits_{k=0}^{n-1}n^{gcd(n,k)} n1k=0n1ngcd(n,k) 式中满足 g c d ( n , k ) = d gcd(n,k)=d gcd(n,k)=d k k k 的数量为 ϕ ( n / d ) \phi(n/d) ϕ(n/d),合并这样的项得到
1 n ∑ d ∣ n ϕ ( d ) n n / d \frac{1}{n}\sum\limits_{d\vert n}\phi(d)n^{n/d} n1dnϕ(d)nn/d 预处理出 n n n 的素因子, D F S DFS DFS 计算所有的约数并统计答案即可。总时间复杂度 O ( t ( n + ∑ d ∣ n log ⁡ n ) ) O\Big(t(\sqrt{n}+\sum\limits_{d\vert n}\log{n})\Big) O(t(n +dnlogn))

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int MOD = 1e9 + 7, MAXLG = 35;
int pn, prime[MAXLG], num[MAXLG];
int T, N;
ll Res;

ll pow_mod(ll x, int n, int mod)
{
    ll res = 1;
    while (n)
    {
        if (n & 1)
            res = res * x % mod;
        x = x * x % mod, n >>= 1;
    }
    return res;
}

void dfs(int k, int n, int ph, int d)
{
    if (k == pn)
    {
        Res = (Res + pow_mod(N, N / d, MOD) * ph % MOD) % MOD;
        return;
    }
    int p = prime[k];
    if (n < num[k])
        dfs(k, n + 1, ph * (n == 0 ? p - 1 : p), d * p);
    dfs(k + 1, 0, ph, d);
}

int main()
{
    ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
    cin >> T;
    while (T--)
    {
        cin >> N;
        pn = Res = 0;
        int t = N;
        for (int i = 2; i * i <= t; ++i)
            if (t % i == 0)
            {
                prime[pn] = i, num[pn] = 0;
                while (t % i == 0)
                    t /= i, ++num[pn];
                ++pn;
            }
        if (t != 1)
            prime[pn] = t, num[pn++] = 1;
        dfs(0, 0, 1, 1);
        cout << Res * pow_mod(N, MOD - 2, MOD) % MOD << '\n';
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值