Sigma Function (LightOJ - 1336)【简单数论】【算术基本定理】【思维】

标签: 入门讲座题解 数论


题目描述

Sigma function is an interesting function in Number Theory. It is denoted by the Greek letter Sigma (σ). This function actually denotes the sum of all divisors of a number. For example σ(24) = 1+2+3+4+6+8+12+24=60. Sigma of small numbers is easy to find but for large numbers it is very difficult to find in a straight forward way. But mathematicians have discovered a formula to find sigma. If the prime power decomposition of an integer is



Then we can write,



For some n the value of σ(n) is odd and for others it is even. Given a value n, you will have to find how many integers from 1 to n have even value of σ.

Input

Input starts with an integer T (≤ 100), denoting the number of test cases.

Each case starts with a line containing an integer n (1 ≤ n ≤ 1012).

Output

For each case, print the case number and the result.

Sample Input

4

3

10

100

1000

Sample Output

Case 1: 1

Case 2: 5

Case 3: 83

Case 4: 947

题意

约数和函数$$\sigma{(n)} = \sum_{d | n} d;.$$

给定\(n\),询问\([1, n]\)区间内有几个\(i\),使得\(\sigma{(i)}\)为偶数?


解析

根据算数基本定理,正整数\(n\),有唯一质因数分解形式,$$n = p_1^{\alpha_1}\cdot p_2^{\alpha_2} \cdot p_3^{\alpha_3} \cdot ,,\cdots ,, \cdot p_n^{\alpha_n}\quad(p_i ;is ;a ;prime).$$

那么,根据乘法计数原理,显然有\(\sigma{(n)} = (1 + p_1^1 + p_1^2 + \cdots p_1^{\alpha_1}) \cdot (1 + p_2^1 + p_2^2 + \cdots + p_2^{\alpha_2}) \cdot (1 + p_3^1 + p_3^2 + \cdots + p_3^{\alpha_3}) \cdot \,\, \cdots \,\, \cdot (1 + p_n^1 + p_n^2 + \cdots + p_n^{\alpha_n})\).

正难则反,我们不方便研究\(\sigma{(n)}\)为偶数的情况,我们可以研究\(\sigma{(n)}\)为奇数的个数,然后用总数减掉奇数个数,就得到偶数个数。

  1. 首先,我们要清楚
  • 偶数 + 偶数 = 偶数

    奇数 + 偶数 = 奇数

    奇数 + 奇数 = 偶数

  • 偶数 * 偶数 = 偶数

    奇数 * 偶数 = 偶数

    奇数 * 奇数 = 奇数。

  1. 我们知道,只有让\(\sigma{(n)}\)的全部因数都为奇数才可以使\(\sigma{(n)}\)为奇数。
  • 若\(2 \,| \,n\),则\((1 + p_1^1 + p_1^2 + \cdots p_1^{\alpha_1})\)这项一定是奇数。因为\(2\)的任何次幂都是偶数,且偶数 + 奇数 = 奇数。

  • 对于除\(2\)以外的其他质数,它的任何次幂都一定是奇数。要想使因数项为奇数,则只能构造($1 + $ 偶数) 的这种形式.当有偶数个奇数相加时,它们的和是偶数。所以,\(\alpha_1,\alpha_2, \alpha_3, \dots,\alpha_n\)(不包括\(2\)的指数)都应该是偶数。

  • \(n\) 可以是一个完全平方数。当\(n\)是一个完全平方数时,\(\alpha_1,\alpha_2, \alpha_3, \dots,\alpha_n\)都是偶数。因为\(n\)可以找到两个完全相同的因子。

    或者,\(n\)可以是$2 \times $ 完全平方数。因为把\(2\)当作底数的因数项永远是奇数,所以乘上\(2\)依然能保持所有乘数项都是奇数。(为什么没有$2^2, 2^3, 2^4, \dots \times $ 完全平方数?当\(2\)的指数为偶数时,用完全平方数就可以找到这个数。如果是奇数时,指数 = 1 + 偶数,又还原为$2 \times $ 完全平方数。)

  • 综上,\(ans = n - \sqrt{n} - \sqrt{n / 2}\)。


通过代码

/*
Problem
LightOJ - 1336
Status
Accepted
Time
151ms
Memory
2084kB
Length
411
Lang
C++
Submitted
2019-11-26 23:30:58
RemoteRunId
1641328
*/ #include <bits/stdc++.h>
using namespace std; typedef long long ll; int main()
{
int times, kase = 0; scanf("%d", &times); while(times --){
ll n, cnt = 0; //cnt也有可能会超过1e9,所以要声明为long long类型.
scanf("%lld", &n); for(ll i = 1; i * i <= n; i ++){
cnt ++; //不超过n的完全平方数计数. if(2 * i * i <= n)
cnt ++; //不超过n/2的完全平方数计数.
} printf("Case %d: %lld\n", ++ kase, n - cnt);
} return 0;
}

Sigma Function (LightOJ - 1336)【简单数论】【算术基本定理】【思维】的更多相关文章

  1. C - Sigma Function LightOJ - 1336 (数论)

    一个让人脑洞大开的题. 题目大意比较简单,询问[1,n]有多少个数其因子和为偶数. 因子分解定理中求因子和的公式是 f(n)=(1+p1+p1^2+p1^3+...+p1^a1)(1+p2+p2^2+ ...

  2. Sigma Function LightOJ - 1336 (约数和为奇数)

    题意: 求1-n中约数和为偶数的数的个数 记住一个定理:...平方数 及其 平方数的2倍 的约数和为奇数  then....减啦 证明: ....我jiao着人家写的很详细,so 看看人家写的吧! 转 ...

  3. Pairs Forming LCM (LightOJ - 1236)【简单数论】【质因数分解】【算术基本定理】(未完成)

    Pairs Forming LCM (LightOJ - 1236)[简单数论][质因数分解][算术基本定理](未完成) 标签: 入门讲座题解 数论 题目描述 Find the result of t ...

  4. Aladdin and the Flying Carpet (LightOJ - 1341)【简单数论】【算术基本定理】【分解质因数】

    Aladdin and the Flying Carpet (LightOJ - 1341)[简单数论][算术基本定理][分解质因数](未完成) 标签:入门讲座题解 数论 题目描述 It's said ...

  5. LightOJ - 1336 - Sigma Function(质数分解)

    链接: https://vjudge.net/problem/LightOJ-1336 题意: Sigma function is an interesting function in Number ...

  6. LightOJ 13361336 - Sigma Function (找规律 + 唯一分解定理)

    http://lightoj.com/volume_showproblem.php?problem=1336 Sigma Function Time Limit:2000MS     Memory L ...

  7. 【LightOJ1336】Sigma Function(数论)

    [LightOJ1336]Sigma Function(数论) 题面 Vjudge 求和运算是一种有趣的操作,它来源于古希腊字母σ,现在我们来求一个数字的所有因子之和.例如σ(24)=1+2+3+4+ ...

  8. 1336 - Sigma Function

    1336 - Sigma Function   PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 MB S ...

  9. Help Hanzo (LightOJ - 1197) 【简单数论】【筛区间质数】

    Help Hanzo (LightOJ - 1197) [简单数论][筛区间质数] 标签: 入门讲座题解 数论 题目描述 Amakusa, the evil spiritual leader has ...

随机推荐

  1. PHP 是如何做垃圾回收的

    PHP 是如何做垃圾回收的 包含 php 5 与 php7 的变量实现和垃圾回收的对比 变量的实现 PHP 的变量是弱类型的,可以表示整数.浮点数.字符串等类型.PHP 的变量是使用结构体 zval ...

  2. 大疆无人机 Android 开发总结——视频解码

    DJI_Mobile_SDK是大疆为开发者提供的开发无人机应用的开发接口,可以实现对无人机飞行的控制,也可以利用无人机相机完成一些视觉任务.目前网上的开发教程主要集中于DJI 开发者社区,网上的资源非 ...

  3. simple go web application & 二维码生成 & 打包部署

    go语言简易web应用 & 二维码生成及解码 & 打包部署 转载请注明出处: https://www.cnblogs.com/funnyzpc/p/10801476.html 前言(闲 ...

  4. 49-在 overlay 中运行容器

    上一节我们创建了 overlay 网络 ov_net1,今天将运行一个 busybox 容器并连接到 ov_net1: 查看容器的网络配置: bbox1 有两个网络接口 eth0 和 eth1.eth ...

  5. 【java】项目中的类名改变

    如果已经开发了一段时间,那如何一次性修改所有文件中的该类类名呢,一个个改太麻烦了还浪费时间,匹配关键字又怕误伤. 选中项目中需要改变的类,按F2键 重命名后eclipse会自动修改.

  6. 你可能会忽略的 Git 提交规范

    一.为什么需要规范? 无规矩不成方圆,编程也一样. 如果你有一个项目,从始至终都是自己写,那么你想怎么写都可以,没有人可以干预你.可是如果在团队协作中,大家都张扬个性,那么代码将会是一团糟,好好的项目 ...

  7. Hyperledger Fabric相关文件解析

    1相关文件说明 这一部分涉及相关配置文件的解析, 网络的启动涉及到多个文件,本文按以下顺序进行分析: . ├── base │   ├── docker-compose-base.yaml #1 │  ...

  8. 浅谈Httpmodules

    HttpModule是ASP.NET过滤器,可以理解为HTTP请求的必经之地我们只要实现IHttpModule接口,就可以取代HttpModule namespace BookShop.Handler ...

  9. NFS深度解析及搭建同步NFS服务

    1.nfs 进程 [root@nfsserver ~]# ps -ef|egrep "nfs|rpc" rpcuser : ? :: rpc.statd -->检查文件一致性 ...

  10. ASP.NET MVC IOC依赖注入之Autofac系列(二)- WebForm当中应用

    上一章主要介绍了Autofac在MVC当中的具体应用,本章将继续简单的介绍下Autofac在普通的WebForm当中的使用. PS:目前本人还不知道WebForm页面的构造函数要如何注入,以下在Web ...