xdu2017校赛F

Problem F Dogs of Qwordance Senior Backend R&D Engineers
问题描述
那年夏天,锘爷和杰师傅漫步在知春公园的小道上。他们的妻子、孩子牵 着狗在前面嬉戏,二人笑语盈盈,他们不深究一个小的编程问题,而是对整个 Qwordance (四字舞蹈)公司的发展前景加以描绘。这样的场景,想想就觉得好 美,想想就好向往,想想就好激动。然而,他们的狗觉得这非常的无聊,决定自 己去玩。 杰师傅的狗非常挑剔。它希望找到一块面积为 x 的长方形广场,还要求广 场的长和宽都是整数。锘爷的狗不屑地说:“这还不简单,总共有 σ0(x) 种方案 呢。”杰师傅的狗却摇了摇头说:“找到这个广场后,我们要在上面画上水平和垂 直的网格,使得水平、垂直网格之间的间距分别是相同的整数。算了这太难了, 我们去听他们讨论 Qwordance 未来发展大方向吧。”锘爷的狗说:“这也不难啊, 总共有,咦,多少方案啊?”杰师傅的狗鄙视道:“你看你连个方案数都算不出, 我不要和你玩了。像你这样的狗在朝鲜是会被做成狗肉火锅的。你走吧。”锘爷 的狗想去问锘爷的儿子(中关村小学生信息学竞赛冠军),然而怕被小主人嘲笑, 请你帮帮它吧。
输入格式 输入包含多组数据(最多 450 组),请处理到文件结束。
每组数据包含一个整数,即 x 。 对于所有数据有 1 ≤ x ≤ 1012。
输出格式 对于每组数据输出 1 行,包含面积为 x 的广场的方案数。
只要广场的长或 宽不同,或网格划分方案不同,就是不同的方案(见样例解释)。
输入输出样例 输入样例 输出样例
1 4
1 10

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 typedef long long ll;
 4 #define N 1000002
 5 int prime[N+3],p;
 6 ll n;
 7 bool is_prime[N+3];
 8 int index[N+3];
 9 void sieve(){
10     p=0;
11     for(int i=0;i<N;i++){
12         is_prime[i]=true;
13     }
14     is_prime[0]=is_prime[1]=false;
15     for(int i=2;i<N;i++){
16         if(is_prime[i]){
17             prime[p++]=i;
18             for(int j=2*i;j<N;j+=i){
19                 is_prime[i]=false;
20             }
21         }
22     }
23 }//埃筛
24 /*void sieve(){
25     is_prime[1]=1;
26     for(ll i=2;i<N;++i){
27         if(!is_prime[i])prime[p++]=i;
28         for(ll j=0;j<p&&prime[j]*i<N;++j){
29             is_prime[prime[j]*i]=1;
30             if(i%prime[j]==0)break;
31         }
32     }
33 }*/
34 //线性筛
35
36 int main(){
37     ios::sync_with_stdio(false);
38     sieve();
39     while(cin>>n){
40         ll ans=1;
41         for(int i=0;1ll*prime[i]*prime[i]<=n;i++){
42             if(n%prime[i]==0){
43                 ll index=0,part=0;
44                 while(n%prime[i]==0){
45                     n/=prime[i];
46                     index++;
47                 }
48                 for(ll j=0;j<=index;j++) part+=(j+1)*(index-j+1);
49                 ans*=part;
50             }
51         }if(n!=1) ans*=4;
52         cout<<ans<<endl;
53     }
54     return 0;
55 }
时间: 2024-11-10 01:13:08

xdu2017校赛F的相关文章

北邮校赛 F. Gabriel&#39;s Pocket Money(树状数组)

F. Gabriel's Pocket Money 2017- BUPT Collegiate Programming Contest - sync 时间限制 2000 ms 内存限制 65536 KB 题目描述 For centuries, Heaven has required its young angels to live and study among humans in order to become full-fledged angels. This is no different

广州工业大学2016校赛 F 我是好人4 dfs+容斥

Problem F: 我是好人4 Description 众所周知,我是好人!所以不会出太难的题,题意很简单 给你n个数,问你1000000000(含1e9)以内有多少个正整数不是这n个数任意一个的倍数 最后友情提供解题代码(我真是太好人了) void solve(int p[], int n) { int ans = 0; for (int i = 1; i <= 1e9; i++) { int fl = 0; for (int j = 0; j < n; j++) { if (i % p[

2015 whu校赛f题big data(dp + 小技巧)

题意是给定五个数n(n <= 100),a,b,l,r 另外有函数序列f(x),其中f(x + 1) = f(x) + a或f(x)+ b,f(0) = 0,问有多少个这样的函数序列f(1)到f(n)使得函数序列的和在l和r之间 解题思路如下: 图片有一处错误,要减去的是a*(n + 1) * n而不是 (b - a)* (n + 1) * n,此外,要注意x/c时向上取整和向下取整的问题. 这道题做做停停一个月了今天终于找时间ac了,有点感人呐 代码如下: #include<cstdio&g

西交校赛 F. GZP and Poker

F. GZP and Poker GZP often plays games with his friends.Today they went to a board game.There are n players(including GZP) and all of them have some virtual money on the table. ith of them has ai yuan. Each player can double his virtual wealth any nu

hust校赛 f题 The tree of hust(lis 变形)

题目大意是给出一段数字序列,可以忽略一次一段连续的序列,求忽略后的最长连续上升子序列 思路是dp,用end数组记录以当前元素作为结尾的最长连续上升序列的元素个数,那么不难得到状态转移方程为 dp(i) = max(dp(i - 1),  max( end[k] ) ) + 1 代码如下: #include<cstdio> #include<cstring> #include<cmath> #include<cstdlib> #include<iostr

CSU 1425 NUDT校赛 I题 Prime Summation

这个题本来有希望在比赛里面出了的 当时也想着用递推 因为后面的数明显是由前面的推过来的 但是在计算的时候 因为判重的问题 ...很无语.我打算用一个tot[i]来存i的总种树,tot[i]+=tot[j]//j为可以由j推到i的一系列数,但这样是不对的,会产生大量重复计算... 看了下标程才发现要用二维来计算出种类总数,f[i][j]+=sum(f[i-j][k]) 表示在推i数的时候,第一个素数为j的种类数,注意j一定为素数,而且k不能大于j...标程里面处理的比较简练,就学了下他的写法. 至

校赛总结

写写校赛总结....... 这两次校赛是我们组队以后第一次的比赛...第一场打得很拙,第二场还可以吧,第一场校赛--毕竟是期待了很久的校赛,所以感觉还是很紧张,吃饭的时候打了二两,剩了一大半==, 这次我们队名叫 I_Love_High_Math......没走到现场,就快下雨了,真的有点郁闷==.到了以后下雨了,和一个队友被困雨中,,出来以后衣服湿了,一开始就悲剧了...     然后一开场就感觉不好.比赛开始的时候,我去写头文件,然后W说A是水题,然后叫我写,平时都是我写第一题的这次我不想开

山科第三届校赛总结

这次山科的校赛算是省赛前的一次正式的检验吧,暴露了我们队伍之前训练很多没发现的问题. 比赛的过程真的算是有惊无险,差点就GG... 我们入场晚了一会,我刚读完C题,就发现已经有人过了F题了,我去看F题,是个统计闰年的水题,很快就敲过了.回去想接着看C,感觉也很水,这时cerberux说这个用个map就A了,我让他来敲,可是他好像用的不是很熟练,这道题敲的很慢,交上去还wa了...我回过头仔细看这题,觉得扫一遍统计一次最多连续出现的次数就可以了,这才把这个水题过了.然后我去敲G,G题我出现了很严重

[第十届校赛]简单总结

这次校赛其实是抱着比较大的期望来打的,首先我是单挑,好像自从去年蓝桥杯后就没有一个人做过比赛,一般都是组队做,这次单挑,是想测测自己的水平和对节奏的把握,也有夺冠的冲动,很可惜,整体上是失败了TAT.如果一开始就稳扎稳打,说不定真的可以题数碾压.. 做完胡老师出的三个水题后,交了一发卡精度的二分,节奏就开始乱了.首先我自认为我的思路很正确,并且已经将误差降到很低了,但陆陆续续wa了7发,wa的原因自然是精度问题.大概比赛结束前2个小时,我把精度加大了一位,居然奇迹般的过了,无语..我一直以为比目