HDU 6069 Counting Divisors

Problem Description
In mathematics, the function d(n) denotes the number of divisors of positive integer n.

For example, d(12)=6 because 1,2,3,4,6,12 are all 12's divisors.

In this problem, given l,r and k, your task is to calculate the following thing :

image.png

Input
The first line of the input contains an integer T(1≤T≤15), denoting the number of test cases.

In each test case, there are 3 integers l,r,k(1≤l≤r≤1012,r−l≤106,1≤k≤107).

Output
For each test case, print a single line containing an integer, denoting the answer.

Sample Input
3
1 5 1
1 10 2
1 100 3

Sample Output
10
48
2302

这个题我觉得还是有必要写个题解的
比赛的时候想了很久,但是脑子发轴,想出来的时候,比赛还有半个小时,当时大的方向虽然想清楚了,小的方面还有点没弄好,所以最后没有AC。唉,难受。
我一步一步来说一下这个题的思路吧。


image.png

首先,看到这个公式有什么想法嘛;
d(n) 是指n这个数包含的因子数
一个数所包含的因子数该怎么计算呢?
比如12
它的质因子是3和2,并且3的个数为1,2的个数为2
那么根据排列组合的原理,在3这个因子上有2中取法,取0或1。在2这个因子有三种取法0,1,2。
那么根据乘法原则12的总因子数应该为23 = 6。
那么d(n^k)呢?
k相当于这个数的质因子个数变成了原来的k倍。
所以d(12^k) = (k+1) * (2k+1);
所以至此可以可出一个结论,一个数n的d(n)等于它的质因子Pi的次方bi乘k加1;
如果 n = P1^b1 + P2^b2 + P3^b3 …… + Pn^bn;
那么d(n) = (b1
k+1) * (b2k+1) * (b3k+1) ……(bnk+1);
那么我们已经解决了怎么算的问题啦。
如果给我足够的时间这时候我已经可以算出来啦!
但是可惜题目给的时间限制是5000ms,而

image.png

所以,拉闸,想办法优化吧
题目给的数据范围是到10^12这个数量级的
我们知道一个任意一个数字都是由他的质因子组成的,质数是构成数字的基本元素。
所以1012这个数量级的合数肯定是由sqrt(1012) = 106这个数量级内的质数构成的。这个结论很好理解吧。合数必定由两个及两个以上的质因子构成。而构成它的质因子中最大的都绝对不会超过106;
max(pi) <10^6
那么我们解决了区间内所有合数的问题;
质数呢?质数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数,这样的数称为质数。
如果n是一个质数,那么d(n) = K+1。
所以我们完全可以用筛法,把给定区间内所有的合数的d(n)值求出来,没有算到的那肯定就是质数了,质数的话就乘(k+1) 。
我们可以开一个数字组R[]保存这个区间内的数字,然后计算这个数字包含的质因子Pi的个数bi时,让这个数字除去Pi^bi,num[i]
=(bi*k+1)。
那要是R[i]没变的那肯定就是没筛到的质数;
然后把每个num[i]的值加起来就可以啦。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容