传送门

参考资料:

  [1]:https://www.2cto.com/kf/201308/233613.html

题意,题解在上述参考资料中已经介绍的非常详细了,接下来的内容只是记录一下我的理解;

我的学习记录:

  定义 f(x) : x的因子个数;

    φ(x) : x之前与x互素的数的个数;

  那么 F(x) = x - f(x) - φ(x) + 1;

  为什么要 +1 呢?

  因为 f(x) 和 φ(x) 同时包含 1 这个数,所以要加上多减去的 1;

  根据算术基本定理:

    任何一个大于1的自然数 N,如果N不为质数,那么N可以唯一分解成有限个质数的乘积

      N=P1a1×P2a2×P3a3×......×Pnan,这里P1<P2<P3......<Pn均为质数,其中指数ai是正整数。

  那么,N的因子肯等为 x = P1b1×P2b2×P3b3×......×Pnbn 这种形式,易知 b1∈[0,a1] , b2∈[0,a2] , ..... , bn∈[0,an],共

      f(x) = (a1+1)*(a2+1)*........*(an+1)个因子;

  如果要使 f(N) 为奇数,那么  (a1+1),(a2+1),........,(an+1) 要全部为奇数,也就是说  a1 , a2 ,........,an 全为偶数,即 N 为完全平方数;

  综上:

    N为完全平方数时,f(N)为奇数;

    N为非完全平方数时,f(N)为偶数;

  接下俩就是求解φ(x),这个是数论中比较重要的公式--欧拉公式;

  定理1:

    如果GCD(a,b) == 1,那么 φ(a*b) = φ(a)*φ(b);

  定理2:

    如果 p 为素数,那么 φ(pk) = pk-1*(p-1);

  (相关证明自行百度,逃);

  定理3:

    那么对于任意大于 2 的数 x = P1a1×P2a2×P3a3×......×Pnan, φ(x) 为偶数;

①如果p为奇数:
根据公式 φ(p^k)=p^(k-)*(p-)
(p-)一定为偶数,则 φ(p^k)为偶数,则 φ(x)为偶数;
②如果p为偶数:
那么,p只能为2;
如果k > ,那么 φ(^k)为偶数;
如果k = ,那么对于大于2的数x,一定会分解出除2的另一个质因子p2,
根据①的得知φ(p2^k2)为偶数;
综上φ(x)为偶数;

定理3简单证明

  综上所述:

    当 x > 2 时:

    ①如果x为完全平方数,那么 F(x) = x - f(x) - ( φ(x) -1) = x - 奇数 - 奇数 = x - 偶数,只有当 x 为奇数时,F(x)为奇数;

    ②如果x为非完全平方数,那么 F(x) = x - f(x) - ( φ(x) -1) = x - 偶数 - 奇数 = x - 奇数,只有当 x 为偶数时,F(x)为奇数;

  所以,[3,x] 中使得 F(i) 为奇数的个数 ⇔ [3,x]中 奇完全平方数+偶非完全平方数 = 偶数-偶完全平方数+奇完全平方数;

  [3,x]中偶数的个数为 x/2 - 1 (减掉的是 2), 平方数个数为 sqrt(x)-1 (减掉的是 1)个;

  如果 (sqrt(x)-1)%2 == 0(sqrt(x)为奇数),那么 偶完全平方数与奇完全平方数 个数相等,F(x) = x/2-1;

  如果 (sqrt(x)-1)%2 ≠ 0(sqrt(x)为偶数),那么 偶完全平方数比奇完全平方数 个数多1,F(x) = x/2-1 -1;

AC代码:

 #include<iostream>
#include<cmath>
#include<cstdio>
using namespace std;
#define ll long long ll n,m; ll Solve(ll x)
{
if(x < )
return ;
ll tot=sqrt(x);
if(tot*tot > x)//sqrt()函数存在精度问题,可能使得tot*tot > x
tot--;
ll ans=x/-;
return ans+((tot% == )?-:);
}
int main()
{
int test;
scanf("%d",&test);
while(test--)
{
scanf("%lld%lld",&n,&m);
printf("%lld\n",Solve(m)-Solve(n-));
}
return ;
}

hdu 4279"Number"(数论)的更多相关文章

  1. HDU 4279 Number(2012天津网络游戏---数论分析题)

    转载请注明出处:http://blog.csdn.net/u012860063? viewmode=contents 题目链接:pid=4279">http://acm.hdu.edu ...

  2. HDU 4279 Number(找规律)

    Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  3. HDU 4279 Number 坑爹的迷之精度

    题目描述 首先定义"special number": 如果对于一个数字B,存在一个数字A(0<A<=B),并同时满足 B%A=0 和 gcd(A,B) != 1 ,那么 ...

  4. HDU 4279 - Number

    2012年天津赛区网赛的题目,想了好久,也没能想出来 还是小杰思路敏捷,给我讲解了一番,才让我把这个题做出来 f(x)=x-phi(x)(1——x与x互素个数)-g(x)(x的因子个数)+1 其中g( ...

  5. hdu 4279 Number(G++提交)

    打表找规律: #include<stdio.h> #include<math.h> #define N 250 bool judge(int i,int j) { ;k< ...

  6. HDU 1005 Number Sequence(数论)

    HDU 1005 Number Sequence(数论) Problem Description: A number sequence is defined as follows:f(1) = 1, ...

  7. HDU 1711 Number Sequence(数列)

    HDU 1711 Number Sequence(数列) Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...

  8. HDU 1005 Number Sequence(数列)

    HDU 1005 Number Sequence(数列) Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...

  9. HDU 4054 Number String

    HDU 4054 Number String 思路: 状态:dp[i][j]表示以j结尾i的排列 状态转移: 如果s[i - 1]是' I ',那么dp[i][j] = dp[i-1][j-1] + ...

随机推荐

  1. tomcat 和jboss区别

    参考http://blog.csdn.net/sz_bdqn/article/details/6762175

  2. LODOP打印控件如何提示用户升级下载安装新版本

    Lodop.C-Lodop在不断完善功能和更新中,新版本修复了很多问题,以及增加很多有利的功能,网站如何更新版本,提示用户下载新版本呢?更新版本很简单,只需要三步:1.替换提示安装部分的自己放置的路径 ...

  3. 学习 Spring (十三) AOP 配置

    Spring入门篇 学习笔记 Spring 所有的切面和通知器都必须放在一个 内(可以配置包含多个 元素),每一个 可以包含 pointcut, advisor 和 aspect 元素(它们必须按照这 ...

  4. 了解AutoCAD对象层次结构 —— 5 —— 块表

    为了清楚的了解块表的组成内容,让我们利用MgdDbg工具查看一下块表中的块表记录.在开始页面,以无样板模式新建一个.dwg文件(图 4‑7(1)),这样的话,默认的块表记录只有3条(图 4‑7(2)) ...

  5. Codeforces Round #432 Div. 1

    A:大胆猜想合法点不会很多,于是暴力检验,一旦发现不合法就break,可以random_shuffle一下. #include<iostream> #include<cstdio&g ...

  6. Python面试题练习

    1.实现1--100之和 #解答一 print sum(xrange(101)) #解答二 s=0 for i in xrange(101): s = s + i print s 2.如何在一个函数内 ...

  7. Python小练习

    1.计算x的n次方 2.计算x的阶乘 3.计算1x1 + 2x2 + 3x3 ...+ NxN之和 def fun(n): s=0 while n > 0: s = s + n*n n = n ...

  8. UOJ356 [JOI2017春季合宿] Port Facility 【启发式合并】【堆】【并查集】

    题目分析: 好像跑得很快,似乎我是第一个启发式合并的. 把玩具看成区间.首先很显然如果有两个玩具的进出时间有$l1<l2<r1<r2$的关系,那么这两个玩具一定在不同的栈中间. 现在 ...

  9. python+unnitest时运行后不执行main函数里面的内容

    1.使用工具pycharm运行unnitest程序遇到的问题 1) 问题:运行后无法生成报告:经print()发现未执行main函数里的内容 2) 原因:使用unnitest测试框架,pycharm运 ...

  10. 运行os.fork()报AttributeError: module 'os' has no attribute 'fork'

    现象 报错代码 def handle(s, c, db): pid = os.fork() if pid == 0: s.close() do_child(c, db) sys.exit() else ...