博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LightOJ - 1336 Sigma function (找规律)
阅读量:6433 次
发布时间:2019-06-23

本文共 1346 字,大约阅读时间需要 4 分钟。

题目中说明对于一个数字n,有如下定义:

唯一分解定理:

σ 函数的定义如下:

现在给出一个n ( 1 <= n <= 10^12 ),问在1到n中有多少个整数k使得 σ(k) 为偶数 ?

 

我们先观察上述式子,发现要想让σ(n)为偶数,那么只要其中有一项(1 <= i <= k )为偶数即可,

我们可以将这个式子变型一下,分子部分可以变为:,约去分母就变为

 

我们可以观察这个式子,我们知道pi都是素数,素数除了2以外都是奇数,所以前面的式子是奇是偶决定于ei的大小,若ei为奇数,就相当于奇数个奇数(若pi不是2,那么肯定是奇数)相加,和是个奇数,再加上1就变成偶数了,反之,若ei为偶数,就相当于偶数个奇数相加再加1,和就是奇数了。如果pi刚好就是2的话,那么上述约去分母之后的式子就是许多偶数相加再加1,这就是个奇数,这个是对σ(n)为偶数没有任何贡献的,所以我们可以直接忽略。

所以我们得出结论:对于n,若将n进行唯一分解之后,如果存在任何一个 pi != 2 且 ei ( 1 <= i <= k )为奇数则 σ(n) 为偶数。

 

现在需要求的是计算1-n之间能让σ(k)为偶数的k的个数。这个有些复杂,因为我们上面说到是有任意一个ei为奇数就可以判出对应的σ值为偶数,这种情况太多太多了,所以我们考虑这个问题的反面:我们求出1-n之间能让σ(k)为奇数的k的个数,这个符合条件的k是很少的(从样例中就能看出来,1000以内能使得σ(k)为奇数的k才53个)。

若σ(n)为奇数,则每一项都必须为奇数,意味着每一项约分之后的都必须为奇数,也就是说每一项的ei都必须是偶数,也就是说n必须为平方数。但是这里有个小问题前面证明过当pi为2时,无论ei是什么,这一项都是奇数。这些平方数乘以2之后,其σ也是奇数(读者可能会问:如果再乘以2呢?其实这就是另一个平方数了,所以我们只需要考虑乘以一个2即可)。

 

所以我们就有了这样的结论:若n为平方数,或为平方数的2倍,那么σ(n)为奇数。

 

我们现在的任务就是生成上述两种数,这个好办,小于n的平方数为sqrt(n)个,这些平方数的2倍的个数是sqrt(n/2)。所以我们的程序很简单:

 

1 #include
2 using namespace std; 3 4 typedef long long LL; 5 typedef unsigned long long ULL; 6 7 int main(){ 8 int T; 9 scanf("%d", &T);10 for(int ca = 1; ca <= T; ++ca){11 LL n, m;12 scanf("%lld", &n);13 m = (LL)sqrt(n+0.5) + (LL)sqrt(n/2+0.5);14 printf("Case %d: %lld\n", ca, n-m);15 }16 return 0;17 }

 

转载于:https://www.cnblogs.com/DynastySun/p/9448485.html

你可能感兴趣的文章
我的友情链接
查看>>
思科通配符(Cisco Wildcard Mask)
查看>>
PHP cURL快速入门
查看>>
在errpt中报E87EF1BE的解决方法(转载)
查看>>
aix chfs及mklvcopy报错的解决方法
查看>>
取消新增的constraints
查看>>
MAC OS X 使用记录
查看>>
Azure 中使用 iPerf 进行网络带宽测试
查看>>
OPTIMIZE TABLE
查看>>
flask框架+pygal+sqlit3搭建图形化业务数据分析平台
查看>>
Fedora24下MySQL开发环境搭建
查看>>
shell实战训练营Day20
查看>>
jQuery 之 TAB切换菜单
查看>>
mysql 数据库集群搭建:(二)3台CentOS-7安装Percona-XtraDB-Cluster-57集群
查看>>
Jenkins实战演练之Windows系统节点管理
查看>>
MySQL高可用架构之MHA
查看>>
excel2013使用分列功能拆分数据
查看>>
如何玩转小程序+公众号?手把手教你JeeWx小程序CMS与公众号关联
查看>>
kibana平台增加安全认证
查看>>
1.8 nginx域名跳转
查看>>