解题思路:





注意事项:因数不会超过这个数的1/2,想到这点可以优化运行时间





参考代码:

#include <iostream>

using namespace std;

int main()

{

    int M, N, i, j, sum=0;

    cin>>N;

    for(M=1;M<N;M++,sum=0)

    {

        for(i=1; i<=M/2; i++)

        {

        if(M%i==0) sum=sum+i;

        }

        if(sum==M)

        {

        cout<<M<<" its factors are ";

        for(j=1;j<=M/2;j++)

            if(M%j==0) cout<<j<<" ";

        cout<<endl;;

        }

     }

 } 

 


点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论