当前位置: 首页 > news >正文

兰州市生态建设管理局网站域名ip地址在线查询

兰州市生态建设管理局网站,域名ip地址在线查询,wordpress 分类缩略图,网页设计素材代码包Powered by:NEFU AB-IN Link 文章目录97. 约数之和题意思路代码97. 约数之和 题意 假设现在有两个自然数 A和 B,S是 A^B的所有约数之和。 请你求出 S mod 9901的值是多少。 思路 ABA^BAB的约数之和为:sumAB(1p1p12...p1Ba1)(1p2p22...p2Ba2)...sum_{A^B…

Powered by:NEFU AB-IN

Link

文章目录

  • 97. 约数之和
    • 题意
    • 思路
    • 代码

97. 约数之和

  • 题意

    假设现在有两个自然数 A和 B,S是 A^B的所有约数之和。
    请你求出 S mod 9901的值是多少。

  • 思路

    ABA^BAB的约数之和为:sumAB=(1+p1+p12+...+p1B×a1)×(1+p2+p22+...+p2B×a2)×...sum_{A^B} = (1 +p_1 + p_1 ^ 2 + ... + p_1^{B×a_1}) × (1 +p_2 + p_2 ^ 2 + ... + p_2^{B×a_2}) × ...sumAB=(1+p1+p12+...+p1B×a1)×(1+p2+p22+...+p2B×a2)×...
    为什么最高项是B×aB×aB×a呢,最高项代表ppp这个质因子的个数,一开始AAAxxxppp,那么A3=A×A×AA^3=A×A×AA3=A×A×A就有3x3x3xppp

    • 做法一:等比数列求和 + 快速幂

      所以,对于每个质因子,根据等比数列求和公式 (1+p+p2+...+pB×a)=pB×a+1−1p−1(1 +p + p ^ 2 + ... + p^{B×a}) = \frac{p^{B×a+1}-1}{p-1}(1+p+p2+...+pB×a)=p1pB×a+11
      那么,对AAA进行质因子分解

      • pB×a+1p^{B×a+1}pB×a+1快速幂
      • 1p−1\frac{1}{p-1}p11费马小定理求逆元,但必须保证p−1p-1p1MODMODMOD互质
        • p−1p-1p1MODMODMOD互质,正常求即可
        • p−1p-1p1MODMODMOD不互质,我们无法求逆元,就换种思路求表达式。因为 p%MOD=1p \% MOD = 1p%MOD=1(1+p+p2+...+pB×a)%MOD=1+B×a×1=1+B×a(1 +p + p ^ 2 + ... + p^{B×a}) \% MOD= 1 + B×a ×1 = 1 + B×a(1+p+p2+...+pB×a)%MOD=1+B×a×1=1+B×a,所以直接返回1+B×a1 + B×a1+B×a即可

      复杂度 O(nlog(n))O(\sqrt{n}log(n))O(nlog(n))

    • 做法二:分治 + 快速幂
      定义 sum(p,k)=(1+p+p2+...+pk)sum(p, k) = (1 +p + p ^ 2 + ... + p^{k})sum(p,k)=(1+p+p2+...+pk),共k+1k +1k+1

      • kkk奇数时,项数为偶数,以下默认k2=⌊k2⌋\frac{k}{2} =\lfloor \frac{k}{2} \rfloor2k=2k
        原式=(p0+p1+...+pk2)+(pk2+1+...+pk)=(p0+p1+...+pk2)+pk2+1×(p0+p1+...+pk2)=(1+pk2+1)×sum(p,k2)=(p^0+p^1+...+p^{\frac{k}{2}}) +(p^{\frac{k}{2} +1}+...+p^k) = (p^0+p^1+...+p^{\frac{k}{2}}) + p^{\frac{k}{2} +1} × (p^0+p^1+...+p^{\frac{k}{2}}) = (1 + p^{\frac{k}{2} +1} ) × sum(p, \frac{k}{2})=(p0+p1+...+p2k)+(p2k+1+...+pk)=(p0+p1+...+p2k)+p2k+1×(p0+p1+...+p2k)=(1+p2k+1)×sum(p,2k)
      • kkk偶数时,转化为奇数情况,sum(p,k)=sum(p,k−1)+pksum(p,k) = sum(p ,k - 1) + p^ksum(p,k)=sum(p,k1)+pk

      复杂度 O(nlog(n)log(n))O(\sqrt{n}log(n)log(n))O(nlog(n)log(n))

    • 超时做法三:递推
      (p0+p1+...+pk)(p^0+p^1+...+p^k)(p0+p1+...+pk),可用递推式,ans = ans * p + 1,但此做法会超时

  • 代码

    做法一

    /** @Author: NEFU AB-IN* @Date: 2023-02-18 11:22:46* @FilePath: \Acwing\97\97.cpp* @LastEditTime: 2023-02-18 23:11:41*/
    #include <bits/stdc++.h>
    using namespace std;
    #define int long long
    #undef int#define SZ(X) ((int)(X).size())
    #define ALL(X) (X).begin(), (X).end()
    #define IOS                                                                                                            \ios::sync_with_stdio(false);                                                                                       \cin.tie(nullptr);                                                                                                  \cout.tie(nullptr)
    #define DEBUG(X) cout << #X << ": " << X << '\n'
    typedef pair<int, int> PII;const int N = 1e5 + 10, INF = 0x3f3f3f3f, MOD = 9901;int quickmod(int a, int b)
    {a %= MOD;int res = 1;while (b){if (b & 1)res = res * a % MOD;a = a * a % MOD;b = b >> 1;}return res % MOD;
    }signed main()
    {IOS;int a, b;cin >> a >> b;if (!a){cout << 0;return 0;}// 质因子分解unordered_map<int, int> mp;for (int i = 2; i <= a / i; ++i){while (a % i == 0){mp[i]++;a /= i;}}if (a > 1)mp[a]++;int ans = 1;auto f = [&](int p, int n) {if ((p - 1) % MOD == 0)return n + 1;int pp = quickmod(p, n + 1);int ny = quickmod(p - 1, MOD - 2);return (pp - 1 + MOD) * ny % MOD;};for (auto [x, cnt] : mp){ans = ans * f(x, cnt * b) % MOD;}cout << ans;return 0;
    }

    做法二

    /** @Author: NEFU AB-IN* @Date: 2023-02-18 12:21:32* @FilePath: \Acwing\97\97.1.cpp* @LastEditTime: 2023-02-19 11:36:53*/
    #include <bits/stdc++.h>
    using namespace std;
    #define int long long
    #undef int#define SZ(X) ((int)(X).size())
    #define ALL(X) (X).begin(), (X).end()
    #define IOS                                                                                                            \ios::sync_with_stdio(false);                                                                                       \cin.tie(nullptr);                                                                                                  \cout.tie(nullptr)
    #define DEBUG(X) cout << #X << ": " << X << '\n'
    typedef pair<int, int> PII;const int N = 1e5 + 10, INF = 0x3f3f3f3f, MOD = 9901;int quickmod(int a, int b)
    {a %= MOD;int res = 1;while (b){if (b & 1)res = res * a % MOD;a = a * a % MOD;b = b >> 1;}return res % MOD;
    }int sum(int p, int k)
    {if (k == 0)return 1;if (k % 2 == 0)return sum(p, k - 1) % MOD + quickmod(p, k) % MOD;return sum(p, k / 2) % MOD * (1 + quickmod(p, k / 2 + 1)) % MOD;
    }int main()
    {IOS;int a, b;cin >> a >> b;if (!a){cout << 0;return 0;}// 质因子分解unordered_map<int, int> mp;for (int i = 2; i <= a / i; ++i){while (a % i == 0){mp[i]++;a /= i;}}if (a > 1)mp[a]++;int ans = 1;for (auto [x, cnt] : mp){ans = ans * sum(x, cnt * b) % MOD;}cout << ans;return 0;
    }
    
http://www.mmbaike.com/news/42266.html

相关文章:

  • 做幼儿网站的目标外贸推广建站
  • 宝山网站建设中国去中心化搜索引擎
  • 动易企业网站网络营销方式与工具有哪些
  • 龙华网站建设设计宁波seo怎么做推广渠道
  • 外贸移动端网站模板西安企业网站seo
  • 做快三网站谷歌seo网站运营
  • com网站注册合肥网络营销公司
  • 网站开发下人员配置软件开发流程八个步骤
  • 手机app软件开发公司排名上海搜索引擎优化1
  • 学做ps的软件的网站有哪些内容百度网址大全电脑版旧版本
  • 电子工程师网站中国新闻
  • 哪些网站做的人比较少最近三天的新闻大事国内
  • 北京网站建设公司排行每日新闻摘要30条
  • 安居客网站应该如何做app软件下载站seo教程
  • unity做网站竞价排名点击
  • 如何选择盐城网站开发跨境电商seo什么意思
  • 南通做网站企业旅游最新资讯 新闻
  • 安徽省建设工程资料上传网站最新的销售平台
  • 山东网站优化公司黑帽seo培训
  • 国外b站免费版长春百度推广公司
  • 邵阳网站建设多少钱网络推广和竞价怎么做
  • 增加网站备案杭州seo公司排名
  • 自己做的网站添加交费功能谷歌优化技巧
  • 学校网站制作公司企业网站seo服务
  • 转做批发鞋子的网站太原seo排名收费
  • 广东快速做网站公司游戏推广引流
  • 满山红厦门网站建设嘉兴seo外包服务商
  • 中国建设银行陕西分行官方网站互联网广告是做什么的
  • 用C语言做网站登录界面自己怎么做一个网页
  • 武汉前端网站开发公司哈尔滨seo优化公司