题意:

给一个数 N ,求 N 范围内所有任意两个数的最大公约数的和。

思路:

f 数组存的是第 n 项的 1~n-1 与 n 的gcd的和,sum数组存的是 f 数组的前缀和。

sum[n]=f[1]+f[2]+f[3]+…+f[n]

sum[n-1]=f[1]+f[2]+…+f[n-1]

sum[n]=sum[n-1]+f[n]

所以我们求出f[n]的值即可

1~n-1与 n 的最大公约数暴力来求肯定超时;

设gcd(x,n)=i 表示 n 和 x 的最大公约数为i,那么gcd( x/i , n/i )=1

即转化为 求n/i 的欧拉函数值。a[ n / i ]

比如:

a [ 6 / 1 ] = a[ 6 ] = 2

a[ 6 / 2 ] = a[ 3 ] = 2

a[ 6 / 3 ] = a[ 2 ] = 1

a[ 6 / 4 ] = a[ 1 ] = 1

a[ 6 / 5 ] = a[ 1 ] = 1

a [ j / i ] * i =2 * 1+2 * 2 + 1 * 3

    for(int i=1;i<N;i++)//计算1~N的所有数
for(int j=i*2;j<N;j=j+i)// [1,n-1] 与n的gcd 的和
//j必须是i的整数倍 ,因为下面要计算 j/i
f[j]+=a[j/i]*i;

欧拉函数数组 a[ n ] 装的是 n 以内与 n互质的数。

欧拉函数表:

    a[1]=1;
for(int i=2;i<N;i++)//欧拉函数表
{
if(!a[i])//素数筛的基础,i 进去的是素数
for(int j=i;j<N;j=j+i)
{
if(!a[j]) a[j]=j;
a[j]=a[j]/i*(i-1);//欧拉公式 φ(n)=n * (1 - 1/p1) * (1 - 1/p2)* .....
}
}

完整代码:

#include<string.h>
#include<stdio.h>
#define N 4000010
typedef long long ll;
ll f[N+5],ans[N+5],a[N+5];
void yao()
{
for(int i=0;i<=N;i++)
f[i]=0,ans[i]=0,a[i]=0;
a[1]=1;
for(int i=2;i<N;i++)//欧拉打表
{
if(!a[i])
for(int j=i;j<N;j=j+i)
{
if(!a[j]) a[j]=j;
a[j]=a[j]/i*(i-1);
}
} for(int i=1;i<N;i++)
for(int j=i*2;j<N;j=j+i)//[1,n-1] 与n的gcd 的和
f[j]+=a[j/i]*i;
// f[6]=a[6/1==1]*1 + a[6/2==3]*2 + a[6/3==2]*3
////// for(int i=1;i<=6;i++)
////// printf("%d ",a[i]);
////// printf("\n");
for(int i=2;i<=N;i++)
ans[i]=ans[i-1]+f[i];
}
int main()
{
int n;
yao();
while(~scanf("%d",&n)&&n)
printf("%lld\n",ans[n]);
return 0;
}
/*
f[6]
1,6 5,6 1=a[6] 2,6 4,6 2=a[3] 3,6 1=a[2] */

UVA - 11426 欧拉函数(欧拉函数表)的更多相关文章

  1. GCD nyoj 1007 (欧拉函数+欧几里得)

    GCD  nyoj 1007 (欧拉函数+欧几里得) GCD 时间限制:1000 ms  |  内存限制:65535 KB 难度:3   描述 The greatest common divisor ...

  2. 【luogu3768】简单的数学题 欧拉函数(欧拉反演)+杜教筛

    题目描述 给出 $n$ 和 $p$ ,求 $(\sum\limits_{i=1}^n\sum\limits_{j=1}^nij\gcd(i,j))\mod p$ . $n\le 10^{10}$ . ...

  3. C++虚函数和虚函数表

    前导 在上面的博文中描述了基类中存在虚函数时,基类和派生类中虚函数表的结构. 在派生类也定义了虚函数时,函数表又是怎样的结构呢? 先看下面的示例代码: #include <iostream> ...

  4. C++虚函数与虚函数表

    多态性可分为两类:静态多态和动态多态.函数重载和运算符重载实现的多态属于静态多态,动态多态性是通过虚函数实现的. 每个含有虚函数的类有一张虚函数表(vtbl),表中每一项是一个虚函数的地址, 也就是说 ...

  5. 20140321 sizeof 虚函数与虚函数表 静态数组空间 动态数组空间 位字段

    1.静态的数组空间char a[10];sizeof 不能用于1:函数类型 2:动态的数组空间new3:位字段 函数类型:int fun();sizeof(fun())计算的是返回类型的大小,并不是函 ...

  6. uva 11426 GCD - Extreme (II) (欧拉函数打表)

    题意:给一个N,和公式 求G(N). 分析:设F(N)= gcd(1,N)+gcd(2,N)+...gcd(N-1,N).则 G(N ) = G(N-1) + F(N). 设满足gcd(x,N) 值为 ...

  7. UVA 11426 GCD - Extreme (II) (欧拉函数+筛法)

    题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=70017#problem/O 题意是给你n,求所有gcd(i , j)的和,其中 ...

  8. UVA 11426 GCD - Extreme (II) 欧拉函数

    分析:枚举每个数的贡献,欧拉函数筛法 #include <cstdio> #include <iostream> #include <ctime> #include ...

  9. UVA 11426 GCD - Extreme (II)(欧拉函数打表 + 规律)

    Given the value of N, you will have to find the value of G. The definition of G is given below:Here ...

  10. UVA 11426 - GCD - Extreme (II) 欧拉函数-数学

    Given the value of N, you will have to find the value of G. The definition of G is given below:G =i< ...

随机推荐

  1. C++走向远洋——51(数组类运算的实现)

    */ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...

  2. shell编程1:变量的使用与例子

    一.Shell脚本的执行通常可以采用以下几种方式: 1):bash script-name或sh script-name(推荐使用) 2):path/script-name 或./script-nam ...

  3. KEMET推出新的多层陶瓷电容器,用于市电供电的应用

    前言:2019年12月2日,全球领先的电子组件供应商KEMET公司 (“ KEMET”或“公司”)推出了一系列新的表面安装设备(SMD)安全认证的多层陶瓷电容器(MLCC),用于市电供电的应用.与现有 ...

  4. localstorage二次封装-模块模式

    var db = function () { // 本地存储前缀,减少命名冲突 var prefix = 'ydb'; return { setPrefix: function (_prefix) { ...

  5. 统计 Django 项目的测试覆盖率

    作者:HelloGitHub-追梦人物 文中所涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 我们完成了对 blog 应用和 comment 应用这两个核心 app 的测试.现在 ...

  6. SpringBoot整合Swagger2案例,以及报错:java.lang.NumberFormatException: For input string: ""原因和解决办法

    原文链接:https://blog.csdn.net/weixin_43724369/article/details/89341949 SpringBoot整合Swagger2案例 先说SpringB ...

  7. 用jQuery怎么做到前后端分离

    传统的web开发模式想必大家都知道,不管是jsp.asp.php或者一些魔板引擎开发,其实道理都是一样的,都是服务端渲染,原理是:浏览器发送一个get请求,服务器对应的返回前端一个html页面,由浏览 ...

  8. 前端javascript知识(一)

    介绍一下 JS 的基本数据类型. Undefined.Null.Boolean.Number.String 介绍一下 JS 有哪些内置对象. Object 是 JavaScript 中所有对象的父对象 ...

  9. .NET Core 获取主机运行资源的库

    简介 CZGL.SystemInfo 是一个支持 Windows 和 Linux 的资源信息获取库,用于获取系统环境.机器资源信息.系统资源使用情况. Nuget 搜索 CZGL.SystemInfo ...

  10. excel排序技术记录

    问题: 给了我一个excel,要求以奖项和编码同时进行排序(奖项优先),但是单元格大小不一样,有数列都是合并了单元格的,同时编码的格式还不一样,有些是SMM-2-07,有些是2-07,所以根本无法进行 ...