#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;
}