题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=2040
大水题。。。
/***** HDOJ 2040 亲和数 ********/
/******** written by C_Shit_Hu ************/
/****************************************************************************/
/*
又是大水题。。。
古希腊数学家毕达哥拉斯在自然数研究中发现,220的所有真约数(即不是自身的约数)之和为:
1+2+4+5+10+11+20+22+44+55+110=284。
而284的所有真约数为1、2、4、71、 142,加起来恰好为220。人们对这样的数感到很惊奇,并称之为亲和数。一般地讲,如果两个数中任何一个数都是另一个数的真约数之和,则这两个数就是亲和数。
你的任务就编写一个程序,判断给定的两个数是否是亲和数
输入数据第一行包含一个数M,接下有M行,每行一个实例,包含两个整数A,B; 其中 0 <= A,B <= 600000 ;
对于每个测试实例,如果A和B是亲和数的话输出YES,否则输出NO。
*/
/****************************************************************************/
// 考察基本的语法问题。。。
// 简单数值如下。。
#include <stdio.h>
int appnum(int num) ;
int main()
{
int M ;
int num_1, num_2 ;
scanf("%d",&M) ;
while (M--)
{
scanf("%d%d", &num_1, &num_2) ;
if (appnum(num_1)==num_2 && appnum(num_2)==num_1)
{
printf("YES\n") ;
}
else
{
printf("NO\n") ;
}
}
return 0;
}
int appnum(int num)
{
int i, sum ;
sum = 0;
for (i = 1; i<num; ++i)
{
if (num%i==0)
{
sum = sum+i ;
}
}
return sum ;
}
/******************************************************/
/******************** 心得体会 **********************/
/*
调用函数可以减少同类代码的复用。
非常好。
水水更健康!!!!
*/
/******************************************************/