大榕树——让我们共成长!
大榕树 myDrs.org
您的位置:大榕树 \ 编程       |  Logo语言   |  Pascal语言   |  信息学奥赛   |  高考保送    |  HTML版本
|  信息学奥赛>>解题报告>>SGOI11之《芝麻开门》         本站全文搜索: 友情提示:

SGOI11之《芝麻开门》
http://www.mydrs.org  5/3/2002  大榕树


问题描述
  对于给定的自然数n和k(1≤n<,1≤k<20),求的所有正整数因子的和。
分析
  (1) 任意大于等于2的正整数都可以被分解质因数,
     则n可以表示成为:
     可以表示成为:
     其中,为素数,,且为任意正整数

  (2) 正整数n的任意约数都可以用n的质因数的积的形式表示。
     例如:n=6时,n的约数有1,2,3,6。
     其中:
解法

  (1)由上面的分析,我们很容易想到递归搜索的解法,依次递归决定各质因数使用次数,构造出的约数,并累加求出总和。由于的约数个数较大,所以程序运行速度很慢,不能再时限内出解。

  (2)我们观察搜索树就能发现,确定了前面的质因子的使用次数,后面的搜索完全一样,我们便可以用记忆化搜索减少重复搜索,速度大大提高。

  (3)由此,我们很容易的找到了求所有约数之和的公式:
 

  (4)在此基础上,我们利用等比数列的求和公式,可以改进公式为:
     

小结
  本题考察了对约数的理解,并在解题中运用了高精度运算。
附:源程序参见 ah02t4.pas


来 源:ChinaSchool
共有2825位读者阅读过此文

  • 上篇文章SGOI11之《黑白图像压缩》
  • 下篇文章SGOI-12友谊赛测试数据

  • 发送邮件
    保存页面 打印文章 HTML版本 发表评论

    □- 近期热门文章 □- 相关文章
    1. NOIP2006竞赛大纲 [8307]
    2. 七类高中生具有保送资格 [5911]
    3. NOI2006获奖选手名单 [4956]
    4. 关于举办NOIP2006模拟赛的通告 [4107]
    5. Turbo Pascal各语句运行速... [3595]
    6. Turbo王者归来新Delphi免费... [3182]
    7. IOI2006我国4名选手全部获得金... [2946]
    8. 关于APIO2007与IOI2007... [2764]
    9. noip倒计时 by 枯叶蝴蝶 [2684]
    10. 朱泽园:思想上的金牌更重要 [2169]
    SGOI第14次友谊赛成绩
    SGOI-14友谊赛测试数据
    SGOI14友谊赛试题
    SGOI第十三次友谊赛数据
    SGOI第13次友谊赛成绩揭晓
    SGOI第十三次友谊赛试题
    SGOI第13次友谊赛竞赛规则
    Sgoi12之《黑白瓷砖》
    《哈利·波特与魔法石》
    Sgoi12之《网络传输》
     

    关于本站 | 合作伙伴 | 联系方式
    大榕树 版权所有 ©1999-2006 www.myDrs.org 闽ICP备05000721号