题意:

给定一个整数L(L<=1e12),计算(x,y,z)组的个数。其中x<y<z,x^2+y^2=z^2,gcd(x,y)==1,gcd(x,z)==1,gcd(y,z)==1。

思路:

以下的方法可用来找出勾股数。设m>n 、 m 和 n 均是正整数,

a = m^2-n^2    b = 2mn   c = m^2+n^2

若 m 和 n 是互质,而且 m 和 n 其中有一个是偶数,计算出来的
(a, b, c) 就是素勾股数

然后我们需要的便是计算m,n互质 qie m,n一奇一偶

因为 m^2*2 = a+c,所以可以求出m的范围 sqrt(l),然后可以求出n的范围t

于是通过枚举m,并求出n,然后对他们进行判断即可

参考knownothing

①当m为偶数时,

如果m <= t,那么n可以取[1,m]中与m互质的数,因为他们一定是奇数

如果m > t,那么n只能取[1,t]中与m互质的数

②当m为奇数时:

如果m <= t,那么n可以取[1,m]中与m/2互质的数,如果ai是[1,m/2]中与m互质的,那么2*ai便是与m互质的偶数

如果m > t,那么n只能取[1,t]中与t/2互质的数

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
typedef long long ll;
typedef long double ld;
const ld eps=1e-10;
const int inf = 0x3f3f3f;
const int maxn = 1e6;
const int MOD = 1e9+7;
bool check[maxn+10];
int prime[maxn+10];
int phi[maxn+10];
int factor[105];
int facnum;
int tot; void phi_and_prime(int N)
{
memset(check,0,sizeof(check));
phi[1] = 1;
tot = 0; for(int i = 2; i <= N; i++)
{
if(!check[i])
{
prime[tot++] = i;
phi[i] = i - 1;
}
for(int j = 0; j < tot; j++)
{
if(i*prime[j] > N) break;
check[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);
}
}
}
} void fac(int x)
{
int tp = x;
facnum = 0;
for(int i = 0; i < tot && prime[i]*prime[i] <= maxn; i++)
{
if(tp % prime[i] == 0)
{
factor[facnum++] = prime[i];
while(tp % prime[i] == 0)
{
tp /= prime[i];
}
}
if(tp == 1)
break;
}
if(tp > 1)
factor[facnum ++ ] = tp; return ;
} ll ans;
void dfs(int cur,int mul,int tot,int n) //搜索实现互斥
{
if(cur == facnum)
{
if(tot & 1) ans = ans - n/mul;
else ans = ans + n/mul;
return ;
}
dfs(cur+1,mul*factor[cur],tot+1,n);
dfs(cur+1,mul,tot,n);
} int main()
{
int T;
ll n;
phi_and_prime(maxn);
scanf("%d",&T);
while(T--)
{
scanf("%I64d",&n);
ll p = sqrt(n + 0.5); //估计m范围
ans = 0;
for(int i = 1; i <= p; i++) //枚举
{
int q = sqrt(n - (ll)i*i + 0.5); //估计n的范围 if(i % 2)
{
fac(i);
if(q >= i) dfs(0,1,0,i>>1);
else dfs(0,1,0,q>>1);
}
else
{
fac(i);
if(q >= i) ans += phi[i];
else dfs(0,1,0,q);
}
}
printf("%I64d\n",ans);
}
return 0;
}

  

hdu 3939(勾股+容斥)的更多相关文章

  1. C - Visible Trees HDU - 2841 -莫比乌斯函数-容斥

    C - Visible Trees HDU - 2841 思路 :被挡住的那些点(x , y)肯定是 x 与 y不互质.能够由其他坐标的倍数表示,所以就转化成了求那些点 x,y互质 也就是在 1 - ...

  2. HDU 5297 Y sequence 容斥 迭代

    Y sequence 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5297 Description Yellowstar likes integer ...

  3. hdu 6053 trick gcd 容斥

    http://acm.hdu.edu.cn/showproblem.php?pid=6053 题意:给定一个数组,我们定义一个新的数组b满足bi<ai 求满足gcd(b1,b2....bn)&g ...

  4. HDU 4609 3-idiots FFT+容斥

    一点吐槽:我看网上很多分析,都是在分析这个题的时候,讲了半天的FFT,其实我感觉更多的把FFT当工具用就好了 分析:这个题如果数据小,统计两个相加为 x 的个数这一步骤(这个步骤其实就是求卷积啊),完 ...

  5. HDU 4336 Card Collector(容斥)

    题意:要收集n种卡片,每种卡片能收集到的概率位pi,求收集完这n种卡片的期望.其中sigma{pi} <=1; 思路:容斥原理.就是一加一减,那么如何算期望呢.如果用二进制表示,0表示未收集到, ...

  6. HDU 4135 Co-prime(容斥+数论)

    Co-prime Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  7. HDU 3970 Harmonious Set 容斥欧拉函数

    pid=3970">链接 题解:www.cygmasot.com/index.php/2015/08/17/hdu_3970 给定n  求连续整数[0,n), 中随意选一些数使得选出的 ...

  8. HDU 4135 Co-prime(容斥:二进制解法)题解

    题意:给出[a,b]区间内与n互质的个数 思路:如果n比较小,我们可以用欧拉函数解决,但是n有1e9.要求区间内互质,我们可以先求前缀内互质个数,即[1,b]内与n互质,求互质,可以转化为求不互质,也 ...

  9. 多校 HDU 6397 Character Encoding (容斥)

    题意:在0~n-1个数里选m个数和为k,数字可以重复选: 如果是在m个xi>0的情况下就相当于是将k个球分割成m块,那么很明显就是隔板法插空,不能为0的条件限制下一共k-1个位置可以选择插入隔板 ...

随机推荐

  1. android context获取目录详解

    获取 sqlite系统数据库路径 方式1: ApkInfo apkInfo = new ResourceUtil(context).getApkInfo(); APP_PATH = new Strin ...

  2. R语言基础1

    ----------------------------------R语言学习与科研应用,科研作图,数据统计挖掘分析,群:719954246-------------------------- 我们将 ...

  3. RE:1054652545 - 论自己是如何蠢死的

    1.Java web 项目中 login/list 文件夹中return "login/list" 反复读取不到对应的jsp文件 一周后检查出来的原因上一级文件夹login前面多出 ...

  4. Three.js three.js Uncaught TypeError: Cannot read property 'getExtension' of null

    在调试Three.js执行加载幕布的时候,突然爆出这个错误three.js Uncaught TypeError: Cannot read property 'getExtension' of nul ...

  5. clang++ 链接问题 和 VS Code

    clang++ 链接问题 和 VS Code 如果你在windows上使用clang 并且同时安装有vs和mingw, clang链接是会自动使用msvs, 链接时会有LINK error LINK ...

  6. SQL SERVER 字符串按数字排序

    需求是这样的: 数据库表里面有一个字段类型是nvachar,存的值是数字和字符混合的,要实现先按数字排序,再按字母倒序. 思路: 考虑这个字段的值是否是有规律可循的,把要按数字排序的部分转换为数字,再 ...

  7. 数据库 MYSQL操作(一)

    数据库  MYSQL操作总结(一) 本文主要介绍一下笔者在使用数据库操作的过程中的一些总结,主要的内容包括一下几个内容: 一.mysql 使用基础(主要包括数据库的安装.基本操作等内容) 二.mysq ...

  8. 新概念英语(1-11)Is this your shirt ?

    Is this your shirt?Whose shirt is white? A:Whose shirt is that? Is this your shirt, Dave? Dave:No si ...

  9. Spring Security 入门(1-2)Spring Security - 从 配置例子例子 开始我们的学习历程

    1.Spring Security 的配置文件 我们需要为 Spring Security 专门建立一个 Spring 的配置文件,该文件就专门用来作为 Spring Security 的配置. &l ...

  10. 由路由器AP隔离引起的WEB服务不能访问的问题

    最近在自己的电脑上运行了一个Web服务,发现它只能被本机访问,无法在同一个局域网的其它设备访问. 于是在网上搜索了各种资料,通通都是在操作系统层面来分析解决问题的. 而我怎么尝试都不成功的情况下,差点 ...