Sumdiv (POJ - 1845,求 A^B 的约数和)

一.题目链接:

POJ-1845

二.题目大意:

求  的约数和 mod 9901 

题目简洁明了,就是不会做。

三.分析:

由唯一分解定理得:A 一定可以表示为  的形式.

那么   可表示为  

因此, 的约数为集合 ,其中 

根据乘法分配律, 的所有约数之和就是:  

上式每一括号内都是等比数列,现在就有两种解法:

① 求逆元

② 分治 + 递归

这里只介绍 ②

现欲使用分治法求  

若 c 为奇数:

若 c 为偶数:

四.代码实现:

#include <set>
#include <map>
#include <ctime>
#include <queue>
#include <cmath>
#include <stack>
#include <vector>
#include <cstdio>
#include <sstream>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#define eps 1e-6
#define pi acos(-1.0)
#define ll long long int
using namespace std;

const int M = (int)2e3;
const int inf = 0x3f3f3f3f;
const ll mod = 9901;

ll quick(ll a, ll b)
{
    ll sum = 1;
    while(b)
    {
        if(b & 1)
            sum = sum * a % mod;
        a = a * a % mod;
        b >>= 1;
    }
    return sum % mod;
}

ll solve(ll p, ll c)
{
    if(!c)
        return 1;
    if(c & 1)
        return solve(p, (c - 1) / 2) * (1 + quick(p, (c + 1) / 2)) % mod;
    else
        return (solve(p, c - 1) + quick(p, c)) % mod;
}

int main()
{
    ll a, b;
    while(~scanf("%lld %lld", &a, &b))
    {
        ll ans = 1;
        for(ll i = 2; i <= sqrt(a); ++i)
        {
            if(a % i == 0)
            {
                ll cnt = 0;
                while(a % i == 0)
                {
                    cnt++;
                    a /= i;
                }
                ans = ans * solve(i, cnt * b) % mod;
            }
        }
        if(a != 1)
            ans = ans * solve(a, b) % mod;
        printf("%lld\n", ans);
    }
    return 0;
}

 

全部评论

相关推荐

07-02 10:39
门头沟学院 Java
Steven267:说点真实的,都要秋招了,还没有实习,早干嘛去了,本来学历就差,现在知道急了,而且你这个简历完全可以写成一页,劣势太大了,建议转测试
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-11 12:31
以前小时候我最痛恨出轨、偷情的人,无论男女,为什么会出轨?现在我成了自己最讨厌的人,没想到分享的东西在牛客会被这么多人看,大家的评价都很中肯,我也认同,想过一一回复,但我还是收声了,我想我应该说说这件事,这件事一直压在我心里,是个很大的心结,上面说了人为什么出轨,我大概能明白了。我们大一下半年开始恋爱,开始恋爱,我给出了我铭记3年的承诺,我对她好一辈子,我永远不会背叛,我责任心太重,我觉得跟了我,我就要照顾她一辈子,我们在一起3年我都没有碰过她,她说往东我就往东,她说什么我做什么,她要我干什么,我就干什么!在学校很美好,中途也出过一些小插曲,比如男闺蜜、男闺蜜2号等等等。但我都强迫她改掉了,我...
牛客刘北:两个缺爱的人是没有办法好好在一起的,但世界上哪有什么是非对错?你后悔你们在一起了,但是刚刚在一起的美好也是真的呀,因为其他人的出现,你开始想要了最开始的自己,你的确对不起自己,21岁的你望高物远,你完全可以不谈恋爱,去过你想要的生活,你向往自由,在一起之后,你要想的不是一个人,而是两个人,你不是变心了,就像你说的,你受够了,你不想包容了,冷静几天是你最优的选择,爱人先爱己。
社会教会你的第一课
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务