Number Theory (Easy) SPOJ - NUMTRYE(数论)(结论类)

f(n) and g(n) are two functions defined as following :

f(n)=(pi2ei+1+1) , where pi is prime factor of n and ei is highest power of pi in n.

g(n)=Σ(ngcd(n,i)) ; 1 <= i <= n

For a given value of n, you have to compute f(n)/g(n) % 1000000007.

Input

First line has T ( <= 10000 ), next T lines has 2 <= n <= 10^12.

Output

f(n)/g(n) % 1000000007 for each test case.

Example

Input:
2
2
4

Output:
3
3
这个怎么说呢,一个结论吧,记住吧,但是不会证明

g(n)=p2ei+1i+1pi+1

所以
f(n)g(n)=pi+1

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
#define N 1000500
#define mod 1000000007
using namespace std;
typedef long long  ll;
bool tag[N];
vector<int> prime;
void getPrime()
{
    for(int i=2;i<N;i++)
        if(!tag[i])
    {
        prime.push_back(i);
        for(int j=i+i;j<N;j+=i)
            tag[j]=true;
    }
}
ll fac[100];
int  k;
int getFac(ll x)
{
    k=0;
    for(int i=0;(ll)prime[i]*prime[i]<=x;i++)
    {
        if(x%prime[i]==0)
        {
            fac[k++]=prime[i];
            while(x%prime[i]==0)
                x/=prime[i];
        }
    }
    if(x>1)
        fac[k++]=x;


}
ll solve()
{
    ll ans=1;
    for(int i=0;i<k;i++)
        ans=ans*(fac[i]+1)%mod;
    return ans;
}
int main()
{
    getPrime();
    int t;
    ll n;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%lld",&n);
        getFac(n);
        printf("%lld\n",solve());
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值