向量的应用——完数与盈数

完数与盈数

https://www.nowcoder.com/practice/df0d850e41894d06a165bf445ec8a8b4?tpId=40&&tqId=31027&rp=1&ru=/ta/kaoyan&qru=/ta/kaoyan/question-ranking

#include <iostream>
#include <cstdio>
#include <vector>
  
using namespace std;

vector<int> numberE;            //由于完数与盈数数量未知,采用vector这样变长数组
vector<int> numberG;

int sum(int x){
    int sum=0;
    for(int i=1;i<x;i++)        //得出数x的该因子(从1开始),并将因子累加到sum中
        if(x%i==0)
            sum +=i;
    return sum;
}

int main(){
    for(int i=2;i<=60;i++){    
        if(i==sum(i))            //一个数如果恰好等于它的各因子子和,如:6=3+2+1,则称其为“完数”
            numberE.push_back(i);
        else if(i < sum(i))        //若因子之和大于该数,则称其为“盈数”。
            numberG.push_back(i);
    }
    printf("E: ");
    for(int i=0;i<numberE.size();i++)
        printf("%d ",numberE[i]);
    printf("G: ");
    for(int i=0;i<numberG.size();i++)
        printf("%d ",numberG[i]);
    return 0;
}
全部评论

相关推荐

07-01 13:37
门头沟学院 Java
steelhead:不是你的问题,这是社会的问题。
点赞 评论 收藏
分享
这是什么操作什么意思,这公司我服了...
斯派克spark:意思是有比你更便宜的牛马了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务