您现在的位置: 中国男护士网 >> 考试频道 >> 计算机等级 >> 二级辅导 >> C语言 >> 辅导 >> 正文    
  C趣味程序(二)(12)求4位以内的相亲数 【注册男护士专用博客】          

C趣味程序(二)(12)求4位以内的相亲数

www.nanhushi.com     佚名   不详 

2.6 相亲数
    2500年前数学大师毕哥达拉斯就发现,220与284两数之间存在着微妙的联系:
    220的真因数之和为:1+2+4+5+10+11+20+22+44+55+110=284
    284的真因数之和为:1+2+4+71+142=220
    毕达哥拉斯把这样的数对A,B称为相亲数:A的真因数之和为B,而B的真因数之和为A。
    相亲数的直接推广是相亲数链:呈连环套形式的多个相亲数。例如,A的真因数之和为B,B的真因数之和为C,C的真因数之和为D,最后D的真因数之和又为A,则A,B,C,D称为一个4环相亲数链。
    数学界寻找相亲数与相亲数链,竟相打破最大相亲数记录的热情不减。

2.6.1 求4位以内的相亲数
    1.算法分析
    对指定区间中的每一个整数i应用试商实施穷举判别。根据相亲数的定义,用试商法(i mod j=0)找出i的所有小于i的真因数j,并求出真因数的和s。然后用同样的方法找出整数s的真因数之和s1。如果有s1=i,则i,s为相亲数对。
    为减少试商j循环次数,注意到数i若为非平方数,它的大于1小于i的因数成对出现,一对中的较小因数要小于i的平方根。若数i愉为整数t的平方,此时t为i的一个因数,而不是一对,因而在和s中减去多加的因数t,这样试商j循环只要从2取到i的平方根t=SQR(i),可大减少j循环次数。缩减程序的运行时间。最后按规格打印所找出相亲数。
程序代码如下:
/*求4位以内的相亲数*/
#include<stdio.h>
#include<math.h>
void main()
{
    int i,j,s,t,s1;
    for(i=11;i<=9999;i++)
    {
        s=1;t=sqrt(i);
        for(j=2;j<=t;j++) if(i%j==0) s=s+j+i/j;
        if(i==t*t)s-=t;        /*求i的真因数之和s*/
        if(i<s)                /*规定i<s,避免重复*/
        {
            s1=1;t=sqrt(s);
            for(j=2;j<=t;j++) if(s%j==0) s1=s1+j+s/j;
            if(s==t*t) s1-=t;        /*求s的真因数之和s1*/
            if(s1==i)
            {
                printf("相亲数:%d,%d\n",i,s);
                printf("%d的真因数之和为:1",i);    /*规格打印相亲数*/
                for(j=2;j<=i/2;j++) if(i%j==0) printf("+%d",j);
                printf("=%d\n",s);
                printf("%d的真因数之和为:%d",s,1);
                for(j=2;j<=s/2;j++) if(s%j==0) printf("+%d",j);
                printf("=%d\n",i);
            }
        }
    }
}
程序运行结果如下:


 

文章录入:杜斌    责任编辑:杜斌 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
     

    联 系 信 息
    QQ:88236621
    电话:15853773350
    E-Mail:malenurse@163.com
    免费发布招聘信息
    做中国最专业男护士门户网站
    最 新 热 门
    最 新 推 荐
    相 关 文 章
    没有相关文章
    专 题 栏 目