鱼C论坛

 找回密码
 立即注册
查看: 2382|回复: 2

题目214:欧拉函数链

[复制链接]
发表于 2016-11-25 04:34:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 欧拉计划 于 2016-11-25 04:37 编辑
Totient Chains

Let φ be Euler's totient function, i.e. for a natural number n, φ(n) is the number of k, 1 ≤ k ≤ n, for which gcd(k,n) = 1.

By iterating φ, each positive integer generates a decreasing chain of numbers ending in 1.
E.g. if we start with 5 the sequence 5,4,2,1 is generated.
Here is a listing of all chains with length 4:

  5,4,2,1
  7,6,2,1
  8,4,2,1
  9,6,2,1
10,4,2,1
12,4,2,1
14,6,2,1
18,6,2,1


Only two of these chains start with a prime, their sum is 12.

What is the sum of all primes less than 40000000 which generate a chain of length 25?



题目:

定义 φ 为欧拉函数:对于任意自然数 n,φ(n) 就是 1 到 n 之间,与 n 互质的数的个数。

如果对 φ 进行迭代,则任一正整数都会生成一个递减到 1 的数列。

比如,我们从 5 开始,则可以得到 5,4,3,2,1 的数列。

下面是所有长度为 4 的数列:

  5,4,2,1
  7,6,2,1
  8,4,2,1
  9,6,2,1
10,4,2,1
12,4,2,1
14,6,2,1
18,6,2,1


上面的数列中,只有两个的初始值是质数,它们(初始值)的总和为 12(5+7)。

请问,小于 40000000 的素数中,哪些能生成长度为 25 的数列,求这些素数的和。


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-4-21 12:41:44 | 显示全部楼层
本帖最后由 永恒的蓝色梦想 于 2020-4-21 13:23 编辑

我觉得这样应该能求出来……
  1. //project euler 214
  2. #include<iostream>
  3. using namespace std;
  4. const int MAX = 40000000;
  5. int phires[MAX], primes[MAX];


  6. int phi(int n) {
  7.     if (phires[n]) {
  8.         return phires[n];
  9.     }

  10.     int i, a, b, c, count = 1;

  11.     for (i = 2; i < n; i++) {
  12.         a = i;
  13.         b = n;
  14.         while (b) {
  15.             c = a % b;
  16.             a = b;
  17.             b = c;
  18.         }
  19.         if (a == 1) {
  20.             count++;
  21.         }
  22.     }

  23.     return phires[n] = count;
  24. }


  25. int main() {
  26.     int i, j, k, sum = 0;

  27.     for (i = 4; i < MAX; i += 2) {
  28.         primes[i] = 1;
  29.     }

  30.     for (i = 3; i < MAX; i += 2) {
  31.         if (!primes[i]) {
  32.             k = i << 1;
  33.             for (j = i; j < MAX; j += k) {
  34.                 primes[j] = 1;
  35.             }
  36.             k = 3;
  37.             for (j = i-1; (j = phi(j)) != 1; k++);
  38.             if (k == 25) {
  39.                 sum += i;
  40.             }
  41.         }
  42.     }

  43.     cout << sum << endl;
  44.     return 0;
  45. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-18 09:18:24 | 显示全部楼层
可以使用筛法来求一个数的欧拉函数值,非常地快。然后枚举即可。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-1 18:51

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表