(Problem 21)Amicable numbers

1547 단어 c오로라 계획
Let d(n) be defined as the sum of proper divisors of n (numbers less than n which divide evenly into n).If d(a) = b and d(b) = a, where a  b, then a and b are an amicable pair and each of a and b are called amicable numbers.
For example, the proper divisors of 220 are 1, 2, 4, 5, 10, 11, 20, 22, 44, 55 and 110; therefore d(220) = 284. The proper divisors of 284 are 1, 2, 4, 71 and 142; so d(284) = 220.
Evaluate the sum of all the amicable numbers under 10000.
 
본제 의 대의:
n 으로 정의 모든 인자 n 또한 제거 할 수 있다 n 의 합.하면, 만약, 만약... b 그리고 d (b) = a, 그리고 a  그러면 a 화해시키다 b 바로 소 개 팅 수 (amicable pair) 입 니 다. 그리고... a 화해시키다 b 모두 친화 수 (amicable number) 라 고 합 니 다.
예 를 들 어 220 의 진 인 자 는 1, 2, 4, 5, 10, 11, 20, 22, 44, 55 와 110 이다.따라서 d (220) = 284. 284 의 진 인 자 는 1, 2, 4, 71 과 142 이다.그래서 d (284) = 220.
10000 이하 의 모든 친화 수의 합 을 계산 하 다.
#include<stdio.h>
#include<math.h>
#include<string.h>
#include<ctype.h>
#include<stdlib.h>
#include<stdbool.h>

int FactorSum(int n)  //  n     n    
{
	int i;
	int sum=1;
	for(i=2; i<=n/2; i++)
	{
		if(n%i==0)
			sum+=i;
	}
	return sum;
}

int main()
{
	int t,i=2;
	int sum=0;
	while(i<10000)
	{
		t=FactorSum(i);
		if(t!=i && FactorSum(t)==i) 
			sum+=i;
		i++;
	}
	printf("%d
",sum); return 0; }

 
Answer:
31626

좋은 웹페이지 즐겨찾기