POJ 2480 Longge's problem 欧拉函数

2024-04-23 19:48

本文主要是介绍POJ 2480 Longge's problem 欧拉函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意: Given an integer N(1 < N < 2^31),you are to calculate ∑gcd(i, N) 1<=i <=N.

题解:

公式:f(N)=∑x*φ(N/x),x | N (x是N的约数)
因为在1···N中,gcd(i,N) = x, 的个数的等于φ(N / x)

另外还可以利用函数的积性:

对于正整数n的一个函数 f(n),当中f(1)=1且当a,b互质,f(ab)=f(a)f(b),在数论上就称它为积性函数。若某函数f(n)符合f(1)=1,且就算a,b不互质,f(ab)=f(a)f(b),则称它为完全积性函数。


不妨令M, N互素
f(M) = ∑d1 * φ(M / d1), d1 | M
f(N) = ∑d2 * φ(N / d2), d2 | N

f(MN) = ∑d * φ(MN / d), d | MN
因为M, N互素,则每个d都可以唯一分解为M中的因子d1, 和N中的因子d2
即d = d1 * d2, d1 | M, d2 | N, d1与d2互素
则d * φ(MN / d) = d1 * d2 * φ(M / d1) * φ(N / d2)
f(MN)中的项与f(M) * f(N)中的项一一对应

解法一:47MS
#include<cstdio>
#include<cstring>
using namespace std;#define MAXN 200000
#define lint __int64
struct Factor { lint b, e; };
Factor f[MAXN]; lint fnum;
lint a[MAXN], p[MAXN], pn;
lint n, ret;void Prime()
{lint i, j; pn = 0;memset(a,0,sizeof(a));for ( i = 2; i < MAXN; i++ ){if ( a[i] == 0 ) p[pn++] = i;for ( j = 0; j < pn && i*p[j] < MAXN && (p[j]<=a[i] || !a[i]); j++ )a[i*p[j]] = p[j];}
}lint Euler ( lint n )
{lint ret = n;for ( int i = 0; p[i] * p[i] <= n; i++ ){if ( n % p[i] == 0 ){ret = ret - ret / p[i];while ( n % p[i] == 0 ) n /= p[i];}}if ( n > 1 )ret = ret - ret / n;return ret;
}void split ( lint n )
{fnum = 0;for ( int i = 0; p[i] * p[i] <= n; i++ ){if ( n % p[i] ) continue;f[fnum].b = p[i]; f[fnum].e = 0;while ( n % p[i] == 0 ){f[fnum].e++;n /= p[i];}fnum++;}if ( n > 1 )f[fnum].b = n, f[fnum++].e = 1;}void DFS ( lint val, int index ) //求n的每一个约数,然后利用欧拉函数
{if ( index == fnum ){ret += Euler(n/val) * val;   //Euler(n/val)的值表示1-n中gcd(n,i)= val的个数return;}for ( lint i = 0, tmp = 1; i <= f[index].e; i++, tmp *= f[index].b )DFS ( val*tmp, index+1 );
}int main()
{Prime();while ( scanf("%I64d",&n) != EOF ){split ( n );ret = 0;DFS ( 1, 0 );printf("%I64d\n",ret);}
}


解法二:利用积性16ms
#include<cstdio>
#include<cstring>
using namespace std;#define MAXN 200000
#define lint __int64
struct Factor { lint b, e, mult; };
Factor f[MAXN]; lint fnum;
lint a[MAXN], p[MAXN], pn;void Prime()
{lint i, j; pn = 0;memset(a,0,sizeof(a));for ( i = 2; i < MAXN; i++ ){if ( a[i] == 0 ) p[pn++] = i;for ( j = 0; j < pn && i*p[j] < MAXN && (p[j]<=a[i] || !a[i]); j++ )a[i*p[j]] = p[j];}
}lint Euler ( lint n )
{lint ret = n;for ( int i = 0; p[i] * p[i] <= n; i++ ){if ( n % p[i] == 0 ){ret = ret - ret / p[i];while ( n % p[i] == 0 ) n /= p[i];}}if ( n > 1 )ret = ret - ret / n;return ret;
}void split ( lint n )
{fnum = 0;for ( int i = 0; p[i] * p[i] <= n; i++ ){if ( n % p[i] ) continue;f[fnum].b = p[i]; f[fnum].e = 0;f[fnum].mult = 1;while ( n % p[i] == 0 ){f[fnum].e++;f[fnum].mult *= p[i];n /= p[i];}fnum++;}if ( n > 1 )f[fnum].b = f[fnum].mult = n, f[fnum++].e = 1;}int main()
{Prime(); lint n;while ( scanf("%I64d",&n) != EOF ){split ( n );lint ret = 1, tmp, sum;for ( int i = 0; i < fnum; i++ ){tmp = 1, sum = Euler(f[i].mult); //所有与f[i].mult互素的数先加起来for ( int j = 1; j <= f[i].e; j++ ){tmp *= f[i].b;sum += Euler(f[i].mult/tmp) * tmp;}ret *= sum;}printf("%I64d\n",ret);}
}


这篇关于POJ 2480 Longge's problem 欧拉函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java8需要知道的4个函数式接口简单教程

《Java8需要知道的4个函数式接口简单教程》:本文主要介绍Java8中引入的函数式接口,包括Consumer、Supplier、Predicate和Function,以及它们的用法和特点,文中... 目录什么是函数是接口?Consumer接口定义核心特点注意事项常见用法1.基本用法2.结合andThen链

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

golang panic 函数用法示例详解

《golangpanic函数用法示例详解》在Go语言中,panic用于触发不可恢复的错误,终止函数执行并逐层向上触发defer,最终若未被recover捕获,程序会崩溃,recover用于在def... 目录1. panic 的作用2. 基本用法3. recover 的使用规则4. 错误处理建议5. 常见错

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

轻松上手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

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个