玩命加载中 . . .

向量的应用


http://t.cn/AiKEyQWW

描述

一个数如果恰好等于它的各因子(该数本身除外)子和,如:6=3+2+1。则称其为“完数”;若因子之和大于该数,则称其为“盈数”。 求出2到60之间所有“完数”和“盈数”。

输入描述:

题目没有任何输入。

输出描述:

输出2到60之间所有“完数”和“盈数”,并以如下形式输出: E: e1 e2 e3 ……(ei为完数) G: g1 g2 g3 ……(gi为盈数) 其中两个数之间要有空格,行尾不加空格。

#define _CRT_SECURE_NO_WARNINGS 1
#include <bits/stdc++.h>
using namespace std;

vector<int> numberE;//完数
vector<int> numberG;//盈数

int Sum(int x) {
	int sum = 0;
	for (int i = 1; i < x; ++i) {
		if (x % i == 0)
			sum += i;
	}
	return sum;
}

int main() {
	for (int i = 2; i <= 60; ++i) {
		if (i == Sum(i))
			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("\n");
	printf("G:");
	for (int i = 0; i < numberG.size(); ++i)
		printf(" %d", numberG[i]);
	printf("\n");
	return 0;
}

文章作者: Jack Tim
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Jack Tim !
评论
  目录