// 一个数如果恰好等于它的各因子(该数本身除外)子和,
// 如:6=3+2+1。则称其为“完数”;若因子之和大于该数,则称其为“盈数”。
// 求出2到60之间所有“完数”和“盈数”。
// 并以如下形式输出: E: e1 e2 e3 ......(ei为完数) G: g1 g2 g3 ......(gi为盈数) 其中两个数之间要有空格,行尾不加空格。

#include <stdio.h>
#include <math.h>

// 求出所有的因子之和
int divisor(int num) {
    int total = 1;
    for (int i = 2; i < sqrt(num); i++) {
        if (num % i == 0) {
            total += i;
            total += num / i;
        }
    }
    if (sqrt(num) == (int)sqrt(num)) {
        total += sqrt(num);
    }
    return total;
}

int main() {
    int good[60] = {0};
    int bad[60] = {0};
    int goodIndex = 0;
    int badIndex = 0;
    for (int number = 2; number <= 60; number++) {
        int result = divisor(number);
        if (result == number) {
            // 如果是完数
            good[goodIndex++] = number;
        } else if (result > number) {
            // 如果是盈数
            bad[badIndex++] = number;
        }
    }
    // 输出结果
    printf("E:");
    for (int i = 0; good[i] != 0; i++) {
        printf(" %d", good[i]);
    }
    printf("\nG:");
    for (int i = 0; bad[i] != 0; i++) {
        printf(" %d", bad[i]);
    }

    system("pause");
    return 0;
}