解题思路:第一步:把这3000个数的因子全部统计下来

              第二步:利用循环在循环中寻找符合条件的数

注意事项:

参考代码:

#include<stdio.h>


int kiss_num()                    //定义亲密数函数

{

int i,j,a[3000],n,k;

for(i=1;i<=3000;i++)      //统计这3000个数的因子

{

    a[i-1]=0;                      //新一轮循环开始前要重新置零

    for(j=1;j<i;j++)

    {

        if(i%j==0)

        {

            a[i-1]=a[i-1]+j;    //把因子相加

        }

    }

}


for(k=2;k<=3000;k++)   //从3000个数中去找

    for(i=2;i<=3000;i++)

    {

        if(a[k-1]==i&&a[i-1]==k&&i<k)  //根据题目要求,选择判断

        {

             printf("(%d,%d)",i,k);

        }

    }

         

}    

}


int main()

{

    kiss_num();    //调用亲密数函数

    return 0;

}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

狂拽斌少 1年前 回复TA
最后没必要双重for