[HDU 5728] PowMod (欧拉函数的积性+欧拉公式降幂+欧拉筛)

2024-06-21 19:48

本文主要是介绍[HDU 5728] PowMod (欧拉函数的积性+欧拉公式降幂+欧拉筛),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

HDU - 5728

K=i=1mϕ(in)mod1000000007
其中 n 是 square-free number
ans=KKKK..modp


先求 K
由于 ϕ(n)是积性函数,所以对于 n 的每个素因子可以提出来计算
i=1mϕ(i×n)=(pk1)×i=1mϕ(i×npk)+i=1mpkphi(i×n)
对于素因子 pk ,如果 i 中不包含这个因子,提出来是 ϕ(pk)=pk1
如果 i 中包含这个因子,那么提出来就是 pk,所以在后面加上多减的这一项
1 m中共有 mpk 个包含 pk i ,为 1×pk2×pk
他们除以 pk 后是 1 2、… mpk ,所以后面 i 是从 1 mpk
K=sum(n,m)=(pk1)×sum(npk,m)+sum(n,mpk)
递归计算即可,复杂度不会超过 (logN)

再求 ans
利用欧拉定理降幂
ax=ax%ϕ(p)+ϕ(p)modp
递归计算, ϕ(p) 很快就变成 1 了,所以复杂度不会超过 (logN)

另外在欧拉函数打表那块,由于 N 107 ,最好用 (N) 的欧拉筛
不然容易 TLE (虽然我用埃氏筛没 TLE

#pragma comment(linker, "/STACK:102400000,102400000")
#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cctype>
#include <map>
#include <set>
#include <queue>
using namespace std;
typedef pair<int,int> Pii;
typedef long long LL;
typedef unsigned long long ULL;
typedef double DBL;
typedef long double LDBL;
#define MST(a,b) memset(a,b,sizeof(a))
#define CLR(a) MST(a,0)
#define SQR(a) ((a)*(a))const int maxn=1e7+10, MOD=1000000007;
int N,M,P;
bool nprim[maxn];
int phi[maxn];
int phi_sum[maxn];
int prime[maxn], pcnt;void prime_init();
LL SUM(int,int,vector<int>&);
LL PowMod(LL,LL);
LL Pow(LL,LL,LL);int main()
{#ifdef LOCALfreopen("in.txt", "r", stdin);
//  freopen("out.txt", "w", stdout);#endifprime_init();while(~scanf("%d%d%d", &N, &M, &P)){vector<int> fact;int tem=N;for(int i=0; i<pcnt && prime[i]<=tem; i++) if(tem%prime[i]==0){tem/=prime[i];fact.push_back(prime[i]);}LL K = SUM(N,M,fact);printf("%lld\n", PowMod(K,(LL)P));}return 0;
}LL PowMod(LL k, LL p)
{if(p==1) return 0;LL tp=PowMod(k,phi[p]);LL res = Pow(k,tp+phi[p],p);return res;
}LL Pow(LL x, LL n, LL p)
{LL res=1;while(n){if(n&1) res=res*x%p;x=x*x%p;n>>=1;}return res;
}LL SUM(int n, int m, vector<int>& fact)
{if(n==1) return phi_sum[m];if(m==1) return phi[n];if(m<1)  return 0;for(int i=0; i<(int)fact.size(); i++) if(n%fact[i]==0)return (SUM( n, m/fact[i], fact) + (LL)(fact[i]-1)*SUM( n/fact[i], m, fact)%MOD)%MOD;return 0;
}void prime_init()
{phi[1]=1;for(int i=2;i<maxn;i++){if(!nprim[i]) {phi[i]=i-1; prime[pcnt++]=i;}for(int j=0;j<pcnt;j++){if(i*prime[j]>=maxn)break;nprim[i*prime[j]]=true;if(i%prime[j]==0){phi[i*prime[j]]=phi[i]*prime[j];break;}else{phi[i*prime[j]]=phi[i]*(prime[j]-1);}}}for(int i=1; i<maxn; i++) phi_sum[i] = (phi_sum[i-1]+phi[i])%MOD;}

这篇关于[HDU 5728] PowMod (欧拉函数的积性+欧拉公式降幂+欧拉筛)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1082166

相关文章

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

poj 3974 and hdu 3068 最长回文串的O(n)解法(Manacher算法)

求一段字符串中的最长回文串。 因为数据量比较大,用原来的O(n^2)会爆。 小白上的O(n^2)解法代码:TLE啦~ #include<stdio.h>#include<string.h>const int Maxn = 1000000;char s[Maxn];int main(){char e[] = {"END"};while(scanf("%s", s) != EO

hdu 2093 考试排名(sscanf)

模拟题。 直接从教程里拉解析。 因为表格里的数据格式不统一。有时候有"()",有时候又没有。而它也不会给我们提示。 这种情况下,就只能它它们统一看作字符串来处理了。现在就请出我们的主角sscanf()! sscanf 语法: #include int sscanf( const char *buffer, const char *format, ... ); 函数sscanf()和

hdu 2602 and poj 3624(01背包)

01背包的模板题。 hdu2602代码: #include<stdio.h>#include<string.h>const int MaxN = 1001;int max(int a, int b){return a > b ? a : b;}int w[MaxN];int v[MaxN];int dp[MaxN];int main(){int T;int N, V;s