POJ-1845 数论

题意就是输入 a,b 输出 a的b次方的因子求和并对9902 取模


这题可以对因子化简

由于唯一分解定理 可以把a表示成 p1^q1*p2^q2...*pn^qn

也就是说 a^b = p1^(q1*b)*p2^(q2*b)...*pn^(qn*b)

由于约数和公式可得a^b得约数求和为(1+p1+p1^2+p1^3+...p1^(q1*b))(1+p2+p2^2+p2^3+...p2^(q2*b))...(1+pn+pn^2+pn^3+...pn^(qn*b))

故问题转化成了如何求等比数列得问题

我们再看 1+p1+p1^2+p1^3+...p1^(q1*b) 可以对其因式分解 从而简化计算

若q*b是偶数 那么一共为奇数项 最终可以化简为 (1+p^(n/2+1) )*(1+p+p^2+...p^(n/2-1))+p^(n/2)

若q*b是奇数 那么一共为偶数项 化简为--> (1+p+p^2+...p^(n/2)*(1+p^(n/2+1))

其中都可以利用一个二分的思想 就是把数列拆开来算


code:

#include<iostream>
#include<cstdio>
#include<cmath>
#include<vector>
using namespace std;
typedef long long ll;const int maxn = 50000000;
const int mod = 9901;
vector<int>p;
int size,a,b;
bool vis[20005];
void prime()
{for(int i=2;i*i<=maxn;i++){if(!vis[i]){p.push_back(i);for(int j=i+i;j*j<=maxn;j+=i)vis[j]=1;}}
}
ll fun(ll aa,ll bb)
{ll ans = 1;aa%=mod;while(bb){if(bb&1)ans = ans*aa %mod;bb>>=1;aa = aa*aa%mod;}return ans%=mod;
}
ll bi(ll x,ll n)
{if(n==0)return 1;else{if(n%2)return (bi(x,n/2)*( 1 + fun(x,n/2+1 ) ))%mod;else return ( bi(x,n/2-1)*( 1 + fun(x,n/2+1 ) )+fun(x,n/2))%mod;}
}
ll solve()
{ll ans=1; ll t = a;for(int i=0;p[i]*p[i]<=a;i++){ll tem =0; //cout<<p[i]<<endl;//system("pause");while(t%p[i]==0)tem++,t/=p[i];tem*=b;ans*=bi(p[i],tem),ans%=mod;	}if(t!=1)ans*= bi(t,b)%mod,ans%=mod;return ans%mod;
}int main()
{ios::sync_with_stdio(0);prime();cin>>a>>b;if(b==0||a<=1)cout<<1<<endl;else cout<<solve()<<endl;return 0;
}

 
#include<iostream>
#include<cstdio>
using namespace std;
const int maxn = 50000000;
const int lim = 10005;
const int mod = 9901;
typedef long long ll;
ll a,b,p[lim],sze;
bool vis[50005];
void prime()
{for(int i=2;i<50005;i++){if(!vis[i]){p[sze++] = i;for(int j=i+i;j<50005;j+=i)vis[j]=1;}}
}
ll fun(ll aa,ll bb,ll m)
{ll ans = 1;aa%=m;while(bb){if(bb&1)ans = ans*aa%m;bb>>=1;aa = aa*aa%m;}return ans%m;
}
ll solve()
{ll ans=1;ll c =a;for(int i=0;p[i]*p[i]<=c;i++){ll tem =0;while(c%p[i]==0)tem++,c/=p[i];if(tem){
//			cout<<p[i]<<" "<<tem<<" "<<c<<endl;ll m = (mod*(p[i]-1));ans = ans*(((fun(p[i],(tem)*b+1,m)-1+m))/(p[i]-1)),ans%=mod;}}
//	cout<<c<<endl;if(c>1){ll m = (mod*(c-1));//cout<<c<<endl;ans = ans*(((fun(c,b+1,m)-1+m))/(c-1)),ans%=mod;}return ans;
}
int main()
{prime();cin>>a>>b;cout<<solve()<<endl;		return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/425667.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

html:(33):文字排版粗体和斜体

文字排版--粗体 我们还可以使用css样式来改变文字的样式&#xff1a;粗体、斜体、下划线、删除线&#xff0c;可以使用下面代码实现设置文字以粗体样式显示出来。 p span{font-weight:bold;} 在这里大家可以看到&#xff0c;如果想为文字设置粗体是有单独的css样式来实现的&…

[剑指offer][JAVA]面试题第[14-1、2]题[剪绳子][Leetcode][第343题][整数拆分][数学][动态规划][背包]

【问题描述】[中等] 给你一根长度为 n 的绳子&#xff0c;请把绳子剪成整数长度的 m 段&#xff08;m、n都是整数&#xff0c;n>1并且m>1&#xff09;&#xff0c;每段绳子的长度记为 k[0],k[1]...k[m-1] 。请问 k[0]*k[1]*...*k[m-1] 可能的最大乘积是多少&#xff1f;…

Java学习笔记4——I/O框架

目录1 流的概念2 流的分类3 字节流文件字节流FileInputStreamFileOutputStream字节缓冲流BufferedInputStreamBufferedOutputStream对象流ObjectOutputStreamObjectInputStream注意事项5 字符流文件字符流FileReaderFileWriter字符缓冲流BufferedReaderBufferedWriter转换流Inp…

snappy

参考From <https://dirtysalt.github.io/snappy.html> Snappy API From <https://www.npmjs.com/package/snappy> Snappy 是一个 C 的用来压缩和解压缩的开发包&#xff0c;其目标不是较大限度压缩&#xff0c;而且不兼容其他压缩格式。Snappy 旨在提供高速压缩速…

2017百度之星资格赛 1003 度度熊与邪恶大魔王

本题我们可以类比背包 背包dp[i][j] 表示再有i个物品下j个空间所获得的最大价值 本题dp[i][j] 可以表示干掉i个血量j个防御力下的最小花费 我们看其实我们就是在不同血量之间转移 如果当前技能的攻击力 > 当前防御力 如果攻击力能干掉怪物那么dp[i][j] min(花费,dp[…

html:(34):下划线和删除线

文字排版--下划线 有些情况下想为文字设置为下划线样式&#xff0c;这样可以在视觉上强调文字&#xff0c;可以使用下面代码来实现&#xff1a; p a{text-decoration:underline;}<p>三年级时&#xff0c;我还是一个<a>胆小如鼠</a>的小女孩。</p> &…

设计模式--职责链模式

实验15&#xff1a;职责链模式 本次实验属于模仿型实验&#xff0c;通过本次实验学生将掌握以下内容&#xff1a; 1、理解职责链模式的动机&#xff0c;掌握该模式的结构&#xff1b; 2、能够利用职责链模式解决实际问题。 [实验任务]&#xff1a;财务审批 某物资管理系统…

uoj#188. 【UR #13】Sanrd(Min_25筛)

题面 传送门 题解 这是一道语文题 不难看出&#xff0c;题目所求即为\(l\)到\(r\)中每个数的次大质因子 我们考虑\(Min\_25\)筛的过程&#xff0c;设 \[S(n,j)\sum_{i1}^nsec_p(i)[min_p(i)\geq P_j]\] 用人话来说的话&#xff0c;就是\(S(n,j)\)表示\(1\)到\(n\)之间所有满足最…

[剑指offer]面试题第[66]题[构建乘积数组][Leetcode][JAVA][第238题][除自身以外数组的乘积][数组]

【问题描述】[中等] 给你一个长度为 n 的整数数组 nums&#xff0c;其中 n > 1&#xff0c;返回输出数组 output &#xff0c;其中 output[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积。示例:输入: [1,2,3,4] 输出: [24,12,8,6]提示&#xff1a;题目数据保证数组之中任…

【发现问题】Java中PrintWriter和BufferedWriter的区别

BufferedWriter: 将文本写入字符输出流&#xff0c;缓冲各个字符从而提供单个字符&#xff0c;数组和字符串的高效写入。通过write()方法可以将获取到的字符输出&#xff0c;然后通过newLine()进行换行操作。BufferedWriter中的字符流必须通过调用flush方法才能将其刷出去。并…

玩转oracle 11g(47):oracle删除非空表空间

DROP TABLESPACE WIICARE INCLUDING CONTENTS AND DATAFILES; --wiicare表空间名

【发现问题】Java中PrintStream和PrintWriter的区别

PrintStream和PrintWriter的API几乎相同&#xff0c;都能输出各种形式的数据&#xff0c;构造方法也几乎相同。两者有何区别&#xff1f; **2个类的功能基本相同&#xff0c;PrintStream能做的PrintWriter也都能实现&#xff0c;并且PrintWriter的功能更为强大。**但是由于Pri…

centos 6.5 安装redis

1. 下载redis&#xff0c;编译安装 下载地址&#xff1a;https://redis.io/download&#xff08;建议大家都选择稳定版本&#xff09; 下载到本地&#xff0c;然后上传到集群 当然也可以通过命令行直接在线下载 $ wget http://download.redis.io/releases/redis-5.0.3.tar.gz $…

[剑指offer][JAVA]面试题第[29]题[顺时针打印矩阵][数组]

【问题描述】[中等] 输入一个矩阵&#xff0c;按照从外向里以顺时针的顺序依次打印出每一个数字。示例 1&#xff1a;输入&#xff1a;matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&#xff1a;[1,2,3,6,9,8,7,4,5] 示例 2&#xff1a;输入&#xff1a;matrix [[1,2,3,4],[5,6,7,…

玩转oracle 11g(48):oracle命令窗口执行sql语句

在plsql里面找到command window&#xff0c;用命令窗口打开

POJ-2407 欧拉函数

本题题意就是要对输入的任意一个1e9内的数字求出其欧拉函数值 根据 欧拉函数 编辑对正整数n&#xff0c;欧拉函数是小于n的正整数中与n互质的数的数目&#xff08;φ(1)1&#xff09;而互质指的是公因数为只有1的两个数&#xff0c;任何数与1都互质根据欧拉公式通式&#xff1…

模块导入以及书写规则

转载于:https://www.cnblogs.com/www-qcdwx-com/p/10419162.html

【应用】Properties类与Properties配置文件的读写

1.Properties类与Properties配置文件 什么是Properties类 Properties&#xff08;Java.util.Properties&#xff09;&#xff0c;该类主要用于读取Java的配置文件&#xff0c;不同的编程语言有自己所支持的配置文件&#xff0c;配置文件中很多变量是经常改变的&#xff0c;为…

并发编程面试题

目录并发编程的优缺点为什么要使用并发编程&#xff08;并发编程的优点&#xff09;并发编程有什么缺点并发编程三要素是什么&#xff1f;在 Java 程序中怎么保证多线程的运行安全&#xff1f;并行和并发有什么区别&#xff1f;什么是多线程&#xff0c;多线程的优劣&#xff1…