【题目描述】
自然数a的因子是指能整除a的所有自然数,但不含a本身。例如12的因子为:1,2,3,4,6。若自然数a的因子之和为b,而且b的因子之和又等于a,则称a,b为一对“亲和数” 。求最小的一对亲和数(a<>b)。
【输入】
(无)
【输出】
1行,分别为a和b(a<b)。
【输入样例】
(无)
【输出样例】
(无)
正确结果:220 284
#include<iostream>
using namespace std;
int sumfactor(int num);//定义函数 因子求和
int main() {
//1、定义函数 因子求和 2、遍历a和b,3、比较 a因子的和=b&&b因子的和=a,终止循环, 输出a和b
bool flag=0;
int sa,sb;
for(int b=1;; b++) {
sb=sumfactor(b);
for(int a=1; a<b; a++) {
if(sb==a) {
sa=sumfactor(a);
if(sa==b) {
cout<<a<<' '<<b;
flag=1;
break;
}
}
}
if(flag)break;
}
return 0;
}
int sumfactor(int num) {//因子求和
int sum=0;
for(int i=1; i<num; i++) {
if(num%i==0) {
sum+=i;
}
}
return sum;
}