Problem E: [Sdoi2013]项链

Time Limit: 30 Sec  Memory Limit: 512 MB
Submit: 427  Solved: 146
[Submit][Status][Discuss]

Description

项链是人体的装饰品之一,是最早出现的首饰。项链除了具有装饰功能之外,有些项 链还具有特殊显示作用,如天主教徒的十字架
链和佛教徒的念珠。 从古至今人们为了美化人体本身,也美 化环境,制造了各种不同风格,不同特点、不同式样的项链,满足了不同肤色、不同民族、不同审美观的人的审美需要。就材料而论,首
饰市场上的项链有黄金、白银、珠宝等几种。珍珠项链为珍珠制成的饰品,即将珍珠 钻孔后用线串在一起,佩戴于项间。天然珍珠项链具有一定的护养作用。 
  
最近,铭铭迷恋上了一种项链。与其他珍珠项链基本上相同,不过这种项链的珠子却 与众不同,是正三菱柱的泰山石雕刻而成的。三菱柱的侧面是正方形构成的,上面刻有数字。 能够让铭铭满意的项链必须满足下面的条件: 
1:这串项链由n颗珠子构成的。 
2:每一个珠子上面的数字x,必须满足0<x<=a,且珠子上面的数字的最大公约数要恰 好为1。两个珠子被认为是相同的,当且仅当他们经过旋转,或者翻转后能够变成一样的。 3:相邻的两个珠子必须不同。 
4:两串项链如果能够经过旋转变成一样的,那么这两串项链就是相同的! 铭铭很好奇如果给定n和a,能够找到多少不同串项链。由于答案可能很大,所以对输 出的答案mod 1000000007。

Input

数据由多组数据构成: 
第一行给定一个T<=10,代表由T组数据。 
接下来T行,每行两个数n和a。

Output

对于每组数据输出有多少不同的串。

Sample Input

1
2 2

Sample Output

3

HINT

对于100%的数据:所有的n<=10^14,a<=10^7,T<=10;

 
题解:JSOI2012 爱之项链升级版,请先做JSOI2012 爱之项链
   推荐博客:http://m.blog.csdn.net/article/details?id=50688526
 #include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<cmath>
#define ll long long
using namespace std;
const int p=1e9+,N=;
int tot,pri[N],mu[N],phi[N];
bool vis[N]; ll a;
ll mod,t1,t3;
long double t2;
struct P{
ll x;
P(){}
P(ll _x):x(_x){}
}n,ans,m,s1,s2,temp,sum[N];
P operator *(P x,P y){
ll t1,t3; long double t2;
t1=x.x*y.x,t2=(long double)x.x*y.x/mod; t3=(ll)(t1-(ll)t2*mod)%mod;
return (P){(t3+mod)%mod};
}
P operator +(P x,P y){return (P)((x.x+y.x)%mod);}
P operator -(P x,P y){return (P)(((x.x-y.x)%mod+mod)%mod);}
ll read()
{
ll x=,f=; char ch;
while (ch=getchar(),ch<''||ch>'') if (ch=='-') f=-;
while (x=x*+ch-'',ch=getchar(),ch>=''&&ch<='');
return x*f;
}
/*P ksm(P x,ll k,ll mod)
{
P res; res.x=1; for (ll i=k; i; i>>=1,x=x*x) if (i&1) res=res*x;
return res;
}*/
P ksm(P x,ll y,ll p){
if (y==) return (P)();
if (y==) return (P)(x.x%p);
P d=ksm(x,y/,p);
if (y&) return d*d*x;
else return d*d;
}
ll phii(ll x){
if (x<N) return phi[x];
ll t=x;
for (int i=;i<=sqrt(x);i++){
if (x%i==){
t=t-t/i;
while (x%i==) x/=i;
}
}
if (x>) t=t-t/x;
return t;
}
P work(ll x)
{
P res; res.x=;
res=ksm((P)(m.x-),x,mod);
if (x&) res=res+(P)(-m.x); else res=res+(P)(m.x-);
res.x=(res.x+mod)%mod;
res=res*(P)(phii(n.x/x));
return res;
}
void prepare()
{
tot=; memset(vis,,sizeof(vis)); mu[]=phi[]=;
for (int i=;i<N;i++){
if (!vis[i]){
mu[i]=-,phi[i]=i-;
pri[++tot]=i;
}
for (int j=;j<=tot;j++){
if (1LL*i*pri[j]>=N) break;
vis[i*pri[j]]=;
if (i%pri[j]==){
mu[i*pri[j]]=,phi[i*pri[j]]=phi[i]*pri[j];
break;
}else mu[i*pri[j]]=-mu[i],phi[i*pri[j]]=phi[i]*phi[pri[j]];
}
}
for (int i=;i<N;i++) sum[i].x=;
for (int i=;i<N;i++) sum[i].x=sum[i-].x+mu[i];
}
int main()
{
prepare();
int T=read();
while (T--)
{
n.x=read(); a=read(); ans.x=; ans.x=m.x=s1.x=s2.x=;
if (n.x%p==) mod=1ll*p*p; else mod=p;
for (int j,i=;i<=a;i=j+){
j=a/(a/i);
s1=s1+(P)(a/i)*(P)(a/i)*(P)(a/i)*(P)(sum[j]-sum[i-]);
s2=s2+(P)(a/i)*(P)(a/i)*(P)(sum[j]-sum[i-]);
}
m=(P)(s1+s2*(P)((ll))+(P)((ll)))*ksm((P)(),1ll*p*(p-)-,mod);
for (int i=; 1ll*i*i<=n.x; i++)
{
if (n.x%i==){
ans=ans+work(i);
if (1ll*i*i!=n.x) ans=ans+work(n.x/i);
}
}
mod=p;
if (n.x%p==)
{
ans.x/=p; temp=(P)(n.x/p); temp=ksm(temp,p-,p);
ans=ans*temp; printf("%lld\n",ans.x%p);
}
else
{
temp=(P)(n.x); temp=ksm(temp,p-,p);
ans=ans*temp; printf("%lld\n",ans.x%p);
}
}
return ;
}

BZOJ3202 [Sdoi2013]项链的更多相关文章

  1. 【BZOJ3202】项链(莫比乌斯反演,Burnside引理)

    [BZOJ3202]项链(莫比乌斯反演,Burnside引理) 题面 BZOJ 洛谷 题解 首先读完题目,很明显的感觉就是,分成了两个部分计算. 首先计算本质不同的珠子个数,再计算本质不同的项链个数. ...

  2. bzoj3202:[Sdoi2013]项链

    思路:首先考虑如何求珠子个数,一个珠子由a,b,c三个数组成且属于区间[1,a],并满足gcd(a,b,c)=1.由于要求本质相同,对于a,b,c这样的一个无序的数列且满足gcd(a,b,c)=1,设 ...

  3. bzoj 3202: [Sdoi2013]项链

    Description 项链是人体的装饰品之一,是最早出现的首饰.项链除了具有装饰功能之外,有些项 链还具有特殊显示作用,如天主教徒的十字架链和佛教徒的念珠. 从古至今人们为了美化人体本身,也美 化环 ...

  4. 洛谷P3307 [SDOI2013]项链 [polya定理,莫比乌斯反演]

    传送门 思路 很明显的一个思路:先搞出有多少种珠子,再求有多少种项链. 珠子 考虑这个式子: \[ S3=\sum_{i=1}^a \sum_{j=1}^a\sum_{k=1}^a [\gcd(i,j ...

  5. [SDOI2013]项链

    description luogu 最近,铭铭迷恋上了一种项链.与其他珍珠项链基本上相同,不过这种项链的珠子却与众不同,是正三菱柱的泰山石雕刻而成的. 三菱柱的侧面是正方形构成的,上面刻有数字. 能够 ...

  6. 洛谷 P3307: bzoj 3202: [SDOI2013] 项链

    题目传送门:洛谷P3307.这题在bzoj上是权限题. 题意简述: 这题分为两个部分: ① 有一些珠子,每个珠子可以看成一个无序三元组.三元组要满足三个数都在$1$到$m$之间,并且三个数互质,两个珠 ...

  7. Luogu3307:[SDOI2013]项链

    传送门 求每个珠子的方案数 即有序的求三元组 \((x,y,z),x,y,z\le a\) 满足 \(gcd(x,y,z)=1\) 设 \(G_i\) 表示 \(i\) 个小于等于 \(a\) 的有序 ...

  8. bzoj 3202 [Sdoi2013]项链——容斥+置换+推式子

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3202 可见Zinn博客:https://www.cnblogs.com/Zinn/p/100 ...

  9. 洛谷 P3307 - [SDOI2013]项链(Burnside 引理+数论)

    题面传送门 看到题目我们显然可以将题目拆分成两部分:首先求出有多少个符合要求的珠子 \(c\),这样我们就可以将每种珠子看成一种颜色,题目也就等价于有多少种用 \(c\) 种颜色染长度为 \(n\) ...

随机推荐

  1. VS2013编译FileZilla0.9.44

    2014年,FileZilla更新了一下,到了44版本了,貌似也是用VS2013的工程做的项目,所以下载了server的安装包,然后安装SourceCode即可(需要安装InterFace,是安装必选 ...

  2. 剑指offer 整数中1 出现的次数

    给定一个十进制正整数N,写下从1开始,到N的所有整数,然后数一下其中出现的所有"1"的个数. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 1 ...

  3. iis7支持asp(访问页面,页面存在仍然提示404)

    1. win7下安装IIS时ASP一般被默认不选中的状态,因此需要打开IIS检查功能视图栏中是否存在ASP选项,若没有则需要从控制面板->程序和 功能->打开或关闭Windows功能-&g ...

  4. 转 通过 spring 容器内建的 profile 功能实现开发环境、测试环境、生产环境配置自动切换

                                      软件开发的一般流程为工程师开发 -> 测试 -> 上线,因此就涉及到三个不同的环境,开发环境.测试环境以及生产环境,通常 ...

  5. The Wall (medium)

    The Wall (medium) Heidi the Cow is aghast: cracks in the northern Wall? Zombies gathering outside, f ...

  6. 把MSSQL的表数据查询成 insert into格式的函数

    USE [db] GO /****** Object: StoredProcedure [dbo].[proc_insert] Script Date: 12/05/2012 17:18:31 *** ...

  7. android脚步---数字时钟和模拟时钟

    时钟UI组件是两个非常简单的组件,分为Digitalclock  和Analogclock, main.xml文件,书中程序有问题,加了两个组件,一个Button和一个<Chronometer ...

  8. [转]JSON详解

    阅读目录 JSON的两种结构 认识JSON字符串 在JS中如何使用JSON 在.NET中如何使用JSON 总结 JSON的全称是”JavaScript Object Notation”,意思是Java ...

  9. Qt5:窗口各类位置

    在Qt程序中获取窗口位置的函数有  geometry()   ,   frameGeometry()  , pos() ,x() , y()等 下面来看看这些函数的区别 还有另外两个函数 size() ...

  10. USACO Section 1.2 Name That Number 解题报告

    题目 题目描述 在一个农场里面,每一头牛都有一个数字编号,但是现在这些牛不喜欢这种编号,它们想把这些数字编号转化成为可以接受的字母的形式.数字与字母的转换表如下: 2: A,B,C 5: J,K,L ...