题解 | #完全数计算#

完全数计算

http://www.nowcoder.com/practice/7299c12e6abb437c87ad3e712383ff84

#include <bits/stdc++.h>
using namespace::std;

bool isPerfectNum(const int &num, unordered_set<uint> &us)
{
    int sum = 0;
    for (auto const &v : us) {
        sum += v;
    }
    return sum == num;
}

void getPrime(const int &i, unordered_set<uint> &us)
{
    for (int j = 2;j <= sqrt(i);j++) {
        if (0 == i % j) {
            us.insert(j);
            us.insert(i / j);
        }
    }
}

int main()
{
    uint num = 0;
    
    while (cin >> num) {
        int cnt = 0;
        unordered_set<uint> us;
        for (int i = 2;i <= num;i++) {
            us.clear();
            us.insert(1);
            getPrime(i, us);
            if (isPerfectNum(i, us)) {
                cnt++;
            }
        }
        cout << cnt << endl;
    }
    
    return 0;
}
全部评论

相关推荐

01-30 22:03
门头沟学院 Java
用微笑面对困难:我滴妈,【俩月】【实习】【主管】仨debuff吃满了,独立设计开发的项目写了绝大占比的运营板块,你独立开发,那维护、问题复盘、日志更新、bug、策划书全是自己整的? 不建议写那么大,可以从小出发更容易
点赞 评论 收藏
分享
03-12 09:57
软件测试
程序员小白条:1)确定测试,测开的方向,技术栈不能写这么少 2)课程凑数的,不是99,100分没必要写 3)实习经历这块要有突出的不是劳动性质的亮点,自己设计的什么方案,什么自动化?什么提效工具?不是一些边角料,人云亦云的东西,没吸引力 4) 校园经历纯没用 5)尽量少写减分项
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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