首页 > 其他 > 详细

牛客练习赛25

时间:2018-08-25 13:33:28      阅读:186      评论:0      收藏:0      [点我收藏+]

链接:https://www.nowcoder.com/acm/contest/158/A
来源:牛客网

q次询问,每次给一个x,问1到x的因数个数的和。

输入描述:

第一行一个正整数q ;
接下来q行,每行一个正整数 x

输出描述:

共q行,每行一个正整数表示答案

示例1

输入

复制
4
1
2
3
10

输出

复制
1
3
5
27

说明

1的因数有1

2的因数有1,2

3的因数有1,3

以此类推

备注:

1<=q<=10 ,1<= x<=10^9


 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 #include <cstdlib>
 5 #include <cstring>
 6 #include <string>
 7 #include <deque>
 8 #include <vector>
 9 #include <set>
10 #include <map>
11 #include <cmath>
12 using namespace std;
13 #define ll long long 
14 int t,n;
15 ll solve(int n)//1~n中所有因子的个数和
16 {
17     ll ans=0;
18     for(int i=1,last;i<=n;i=last+1){//sqrt(N)的复杂度
19         last=n/(n/i);//分块  : 5/3 5/4 5/5 3 4 5 都出现了一次
20         ans+=(ll)(n/i)*(last-i+1);//n/i :i作为因子共出现的次数
21     }
22     return ans;
23 }
24 int main()
25 {
26     scanf("%d",&t);
27     while(t--)
28     {
29         scanf("%d",&n);
30         printf("%lld\n",solve(n));
31     }
32     return 0;
33 }

 

牛客练习赛25

原文:https://www.cnblogs.com/tingtin/p/9533033.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!