NYOJ478 月老的烦恼(1)

2014-11-24 09:38:58 · 作者: · 浏览: 1

直接打表。


 
#include 
  
   
#define MAX 500000 + 2
int a[MAX];

void count(){
	int t = MAX / 2, i, j;
	for(i = 1; i != t; ++i)
		for(j = i * 2; j <= MAX; j += i)
			a[j] += i;
}

int main(){
	int t, n;
	count();
	scanf("%d", &t);
	while(t-- && scanf("%d", &n))
		printf("%d\n", a[n]);	
	return 0;
}