注册 登录
编程论坛 C语言论坛

亲密数对

m3440426898 发布于 2022-04-12 19:41, 871 次点击
为什么是i<=a/2和i<=b/2,不是i<=a和i<=b;还有为什么是i<=b/2。
#include<stdio.h>
int main()
{
    int a, i, b, n;
    printf("There are following friendly--numbers pair smaller than 3000:\n");
    for( a=1; a<3000; a++ )  /*穷举3000以内的全部整数*/
    {
        for( b=0, i=1; i<=a/2; i++)  /*计算数a的各因子,各因子之和存放于b*/
            if(!(a%i))
                b+=i;
        for( n=0, i=1; i<=b/2; i++ )  /*计算b的各因子,各因子之和存于n*/
            if(!(b%i))
                n+=i;
        if(n==a && a<b)  /*使每对亲密数只输出一次*/
            printf("%4d--%4d    ", a, b);  /*若n=a,则a和b是一对亲密数,输出*/
    }
    return 0;
}
1 回复
#2
rjsp2022-04-12 22:37
什么是“亲密数对”?还得浪费时间去网上搜;
“为什么是i<=a/2和i<=b/2,不是i<=a和i<=b” --- 有大于自身一半的因子吗?这个因子乘以什么因子得到原始数?
“还有为什么是i<=b/2” --- 与上一个问题是一样的吧?除1之外,第一个因子最小可能是2,那么最后因子最大可能是n/2
1