看到这是一道紫题还是和gcd有关的才点进来(毕竟数论只会gcd).

前置芝士

  1. 质数**(又称素数):因数只有1和本身,但是很特殊的1不是一个质数.
  2. gcd**:欧几里得算法,又称辗转相除法,可以在约为O(LogN)的时间复杂度内求出两个数的最大公约数(N为两个数中大的那个数,在两数为相邻的斐波那契数时最慢,具体不证明其实就是我不会).
  3. 欧拉函数**:一个非常基本的数论函数,是一个积性函数(虽然本题并没有考到),欧拉函数可以表示为\(\varphi(x)\),表示小于x的自然数中与x互质的数的个数(具体求法下文会讲到).

推导公式

很明显,直接暴力需要O(N^2)的时间发咋读但是N有1e7肯定是会T的,所以需要从gcd(a,b)为一个质数入手.

当\(gcd(a,b)==1\)时不难发现\(gcd(a*p,b*p)==p\)(p为任何自然数时都成立),于是乎可以先把0~N中的素数筛出来.

那么下面要怎么知道一个素数可以产生几对符合条件的a,b呢?

可以发现\(max(a,b)*p\leq N\Rightarrow max(a,b)\leq \dfrac {N}{p}\)因为a,b都为整数,所以\(max(a,b)\leq \lfloor\dfrac {N}{p}\rfloor\),于是就要知道小于p的互质的数对的个数了,拿出前置芝士中的欧拉函数,于是小于p的数的对数\(=2*\sum ^{\tiny\lfloor\dfrac {N}{p}\rfloor}_{i=1}\varphi \left( i\right)\)(因为如(1,2)和(2,1)同时成立,所以需要乘2),每次都要求自然还是会T,所以需要用到前缀和优化一下.

具体做法

欧拉函数的具体实现:(本人太菜,只会用埃氏筛)

对于x不是质数\(\varphi(x)=x*\prod ^{n}_{i=1}(1-\dfrac {1}{p_{i}})\)(其中\(p_{i}\)为为x质因数,n为x的质因数的个数)

x为质数时\(\varphi(x)=x-1\),其中十分特殊的\(\varphi(1)=1\).

这样可以直接套入埃氏筛中将所有\(1\leq x\leq N\)的\(\varphi(x)\)求出,再用一个sum数组统计起来.

如果还不是很了解可以康康例题.

代码

#include<bits/stdc++.h>
#define rap(i,first,last) for(int i=first;i<=last;++i)
using namespace std;
const int maxN=1e7+5;
int N;
double phi[maxN];
bool boo[maxN];
long long sum[maxN];//注意开long long
int main()
{
scanf("%d",&N);
rap(i,1,N)
{
boo[i]=1;
phi[i]=i;//先赋值为i方便处理
}
boo[1]=0;//不是质数
rap(i,2,N)//埃氏筛的部分
if(boo[i])
{
phi[i]=i-1;
rap(j,2,N/i)
{
boo[i*j]=0;
phi[i*j]*=1.0-1.0/i;//求出欧拉函数的值
}
}
sum[1]=1;//1时因为只有(1,1)所以不用乘二
rap(i,2,N)
sum[i]=sum[i-1]+1ll*((int)phi[i])*2;//用前缀和优化
long long answer=0;//注意long long
rap(i,2,N)
if(boo[i])answer+=sum[N/i];//把每个质数所带来的(a,b)全部相加
printf("%lld",answer);//输出answer
return 0;
}

数论题的题解好难写

「Luogu P2568 GCD」的更多相关文章

  1. Luogu P2568 GCD

    我们首先发现这样肯定是做不了的,所以我们枚举为\(gcd(x,y)=d\)的\(d\) 然后考虑以下的性质: \(gcd(x,y)=1 \Leftrightarrow gcd(px,py)=p(p为素 ...

  2. NOIP模拟测试23「mine·water·gcd」

    mine 题解 一道比较水的dp 考试因为初始化挂掉了只有$80$分 代码有注释 #include<bits/stdc++.h> using namespace std; //无脑dp # ...

  3. 「Luogu P3680 凸轮廓线」

    一道神奇的计算几何题 前置芝士 正三角形,正方形,圆:什么,您都会,那真是太好了. 三角函数的运用:因为我不是很想在这一块写太多,具体可以自行百度. 推导公式 对于一串是圆和正方形开头和结尾时是十分好 ...

  4. Libre 6009 「网络流 24 题」软件补丁 / Luogu 2761 软件安装问题 (最短路径,位运算)

    Libre 6009 「网络流 24 题」软件补丁 / Luogu 2761 软件安装问题 (最短路径,位运算) Description T 公司发现其研制的一个软件中有 n 个错误,随即为该软件发放 ...

  5. Libre 6007 「网络流 24 题」方格取数 / Luogu 2774 方格取数问题 (网络流,最大流)

    Libre 6007 「网络流 24 题」方格取数 / Luogu 2774 方格取数问题 (网络流,最大流) Description 在一个有 m*n 个方格的棋盘中,每个方格中有一个正整数.现要从 ...

  6. Libre 6006 「网络流 24 题」试题库 / Luogu 2763 试题库问题 (网络流,最大流)

    Libre 6006 「网络流 24 题」试题库 / Luogu 2763 试题库问题 (网络流,最大流) Description 问题描述: 假设一个试题库中有n道试题.每道试题都标明了所属类别.同 ...

  7. Libre 6005 「网络流 24 题」最长递增子序列 / Luogu 2766 最长递增子序列问题(网络流,最大流)

    Libre 6005 「网络流 24 题」最长递增子序列 / Luogu 2766 最长递增子序列问题(网络流,最大流) Description 问题描述: 给定正整数序列x1,...,xn . (1 ...

  8. Luogu 2764 最小路径覆盖问题 / Libre 6002 「网络流 24 题」最小路径覆盖 (网络流,最大流)

    Luogu 2764 最小路径覆盖问题 / Libre 6002 「网络流 24 题」最小路径覆盖 (网络流,最大流) Description 给定有向图G=(V,E).设P是G的一个简单路(顶点不相 ...

  9. Luogu 2762 太空飞行计划 / Libre 6001 「网络流 24 题」太空飞行计划 (网络流,最大流)

    Luogu 2762 太空飞行计划 / Libre 6001 「网络流 24 题」太空飞行计划 (网络流,最大流) Description W 教授正在为国家航天中心计划一系列的太空飞行.每次太空飞行 ...

随机推荐

  1. Bugku-CTF社工篇之简单的个人信息收集

  2. 翻页插件 jquery

    //css <style> * { padding:; margin:; list-style: none; } .wrapper { width: 100%; cursor: point ...

  3. Debian9安装Metasploit

    参考博文:https://www.jianshu.com/p/ea0629b9e367 0x0 添加Kali源 deb http://http.kali.org/kali kali-rolling m ...

  4. NAT-T和PAT(IPSec)

    ¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥NAT-T技术介绍¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥¥ 为什么TCP和UDP不能穿越:TCP和UDP有一个IP头的尾部校验(校验头部和负载 ...

  5. jquery中 $(xxx).each() 和 $.each()的区别,以及enter键一键登录

    1.$().each 在dom处理上面用的较多.如果页面有多个input标签类型为text,对于这时用$().each来处理多个text,例如: $("input[type=’text’]& ...

  6. 一次从Github向Gitee迁库踩坑记录

    先上结论:gitee的lfs功能收费,直接从github迁移包含lfs管理的文件会出错,配置lfs.url即可解决问题 Q: 为什么要迁库呢? A: github访问太慢了,不然我也不想费这个功夫! ...

  7. Vulnhub_DC1 记录

    目录 Vulnhub_DC1 记录 经验 & 总结 步骤流水 1. 建立立足点 2. 提权 3. 主机信息搜集 4. 继续提权 5. 消失的flag Vulnhub_DC1 记录 参考walk ...

  8. POJ 2104 主席树模板题

    #include <iostream> #include <cstdio> #include <algorithm> int const maxn = 200010 ...

  9. PTA的Python练习题(一)

    最近宅家里没事干,顺便把python给学了.教程和书看了一段时间,但是缺少练习的平台. 想起大一时候练习C语言的PTA平台,就拿来练手了. (因为没有验证码无法提交题目,所以自己用pycharm来做题 ...

  10. Solr搜索引擎服务器学习笔记

    Solr简介 采用Java5开发,基于Lucene的全文搜索服务器.同时对其进行了扩展,提供了比Lucene更为丰富的查询语言,同时实现了可配置.可扩展并对查询性能进行了优化,并且提供了一个完善的功能 ...