问一道acm的题,提交时老实说超时.
问一道acm的题,提交时老实说超时.Descriptionzyf最喜欢的数字是1!所以他经常会使用一些手段,把一些非1的数字变 成1,并为此得意不已.他会且仅会的两种手段是:1.把某个数m除以某个质数p——当然p必须能整除这个数,即m=m/p 2.把某个数m减1,即m=m-1 有一天他突发奇想,想把[a,b]区间中所有的数一个一个地变成1,这是一个巨大的无聊的工程,所以他想知道他最少得花多少操作才能达到目 的.Input输入包含多组数据(1000组数据),EOF结束.每组数据以两个整数开头:a,b(0
最佳回答
你的算法的时间复杂度太高了,对于每个区间的每个数字都要处理,而且还要给这个数字进行素数分解,那么时间复杂度为1000 (case) * 100000 (b-a) * 100000 (i) = 10^13 那显然是不行的了。给你下我的想法:1。筛法筛出2-100000的所有素数,在用素数P筛去一个合数Q的时候,要将P记录下来,保存在a[Q]中(a[Q]=P) 算法复杂度为o( n * log log n )2。筛完以后,用o(n)的算法从小到大计算出每个数拥有的质因数个数( 当i为合数时c[i]=c[i/a[i]]+1 而c[i/a[i]]在之前已算出) 算法复杂度为o( n )3。构造sum数组记录c[0-i]的和放入sum[i] 算法复杂度为o( n )4。对于询问a-b输出sum[b]-sum[a-1]即可 算法复杂度为o( case )于是总复杂度为n log log n接近o (n)了 不会超过10^6,一秒内就能跑完了
最新回答共有2条回答
-
2026-03-30 17:35:51自觉的鸡
回复你的算法的时间复杂度太高了,对于每个区间的每个数字都要处理,而且还要给这个数字进行素数分解,那么时间复杂度为1000 (case) * 100000 (b-a) * 100000 (i) = 10^13 那显然是不行的了。给你下我的想法:1。筛法筛出2-100000的所有素数,在用素数P筛去一个合数Q的时候,要将P记录下来,保存在a[Q]中(a[Q]=P) 算法复杂度为o( n * log log n )2。筛完以后,用o(n)的算法从小到大计算出每个数拥有的质因数个数( 当i为合数时c[i]=c[i/a[i]]+1 而c[i/a[i]]在之前已算出) 算法复杂度为o( n )3。构造sum数组记录c[0-i]的和放入sum[i] 算法复杂度为o( n )4。对于询问a-b输出sum[b]-sum[a-1]即可 算法复杂度为o( case )于是总复杂度为n log log n接近o (n)了 不会超过10^6,一秒内就能跑完了
热门文章
- 康达学院专转本五年制
- 高考一个考场分ab卷吗
- not only but also用法
- 某物体做自由落体运动,从释放开始计时,则物体在前2s内的平均速度为______m/s,物体下落2m时的速度大小为______m/s.
- 三角函数公式大全表格
- 地理中考必背知识点2022
- 2013-2014学年小学六年级科学上学期期末考试试卷及答案
- 人教版2014-2015学年小学五年级英语第二学期期中教学质量检测试卷及答案
- 【Linux驱动开发】设备树详解(二)设备树语法详解
- 别跟客户扯细节
- 在别的城市买房子能落户吗
- 卖房前要把装修贷还完吗
- 高中政治教学提高教学效果的方法探究
- “互联网+”背景下的初中英语课堂教学改革与创新策略研究
- 2022年终止合同范本
- 租房合同范本范文
- 如何挑选土豆
- 如何挑选土鸡
