南阳理工OJ 478 月老的烦恼(1)(打表约数和模板)
连接:http://acm.nyist.net/JudgeOnline/problem.php?pid=478
?
月老最近遇到了一个很棘手的问题,就是“剩男”“剩女”急速增长,而自己这边又人手不足导致天天都得加班。现在需要你来帮助月老解决这个问题,牵红绳的规则很简单:每个男生都一个编号n(1<=n<=500000),编号n的因数之和就是要牵线的女生的编号。
如20的因子是:1,2,4,5,10;
?
?321012
1816
?
#include <stdio.h>#include<math.h>#define A 500001int a[A]={0,0};int main(){ int n,m,i,j,t=sqrt(A); for(i =2;i<A;i++) a[i]=1; for(i=2;i<=t;i++) for(j=i;i*j<=A;j++) if(i==j) { a[i*j]+=i; } else { a[i*j]+=j+i; } scanf("%d",&n); while(n--) { scanf("%d",&m); printf("%d\n",a[m]); } return 0;}?
?