寻找n以内的亲密数对


MOOC的测验题目如下:

寻找n以内的亲密数对
代码格式如下:

def fac(n):
...
return xxx

n = int(input()) # 此处输入由系统自动完成不需要自己输入,只要写这样一条语句即可...(3分)

题目内容:
对于两个不同的整数A和B,如果整数A的全部因子(包括1,不包括A本身)之和等于B;且整数B的全部因子(包括1,不包括B本身)之和等于A,则将A和B称为亲密数。自定义函数fac(x)计算x包括1但不包括本身的所有因子和并返回。从键盘输入整数n,调用fac()函数寻找n以内的亲密数并输出。注意每个亲密数对只输出一次,小的在前大的在后,例如220-284。

输入格式:
按提示用input()函数输入
输出格式:
按样例形式,可使用形如“print("{}-{}".format(参数1, 参数2))”输出语句进行亲密数对的输出
输入样例:
500
输出样例:
220-284



网上搜索到用C语言写的

#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 < 500; a++)
    {    
        for (b = 0, i = 1; i <= a / 2; i++ )
        {
            if(! (a % i)) 
            {
                b += i;
            }    
        }
        for (n = 0, i = 1; i <= b/2; i++)
        {
            if(! (b % i)) 
            {
                n += i;
            }
        }
        if(n == a && a < b)
        {
            printf("%4d..%4d\n", a, b); 
        }
    }   
    return 0;
}
python的代码(参考别人的):
def fac(n): 
    
    for a in range(2,n+1):
        b = 0
        for i in range(1,a):
            if a%i==0:
                b +=i
        d = 0
        for i in range(1,b):
            if b%i==0:
                d +=i
        if d==a and d !=b:
            if a < b:
                print("{}-{}".format(a,b))

n = int(input("在这里输入(但是题目里要求不需要文字):")) 
e = fac(n)
posted @ 2020-04-04 09:18  tomoya0307  阅读(935)  评论(0编辑  收藏  举报