题目链接 http://acm.hdu.edu.cn/downloads/CCPC2018-Hangzhou-ProblemSet.pdf

B题 数论题      h(n)=∑ d|n φ(d) × n /d   求一个数的h值   我们只要意识到他是一个积性函数就解决了  这个函数看起来很像狄利克雷卷积 我们构造一个函数f(n)=n;h(n)=∑ d|n φ(d) × f(n /d)

欧拉函数φ是积性函数 构造的f是完全积性函数 所以他们的狄利克雷卷积h也是积性函数  然后推导一下答案就是 ∑(pi^qi+(pi-1)*qi*pi^(qi-1))  (1<=i<=m)

其实当你没有意识到他是一个积性函数    推导的时候也可以发现他可以用组合情况写   这就用到了子集生成知识了很简单一个dfs就可以了 m最大20 子集个数最大就是2^20 可以接受

然后枚举子集就可以得到结果了

关于  积性函数和狄利克雷卷积推荐几个博客  https://www.cnblogs.com/jianglangcaijin/p/6035766.html#undefined

                    https://blog.csdn.net/liyizhixl/article/details/79997478

                    https://www.cnblogs.com/wfj2048/p/6537861.html

积性函数性质

1.若n=pa11pa22pa33...pannn=p1a1p2a2p3a3...pnan,那么f(n)=f(pa11)f(pa22)f(pa33)...f(pann)f(n)=f(p1a1)f(p2a2)f(p3a3)...f(pnan)。
2.若ff为积性函数且有f(pn)=fn(p)f(pn)=fn(p),那么ff为完全积性函数。

狄利克雷卷积性质:

  1. (f∗g)=∑d|nf(d)g(nd)(f∗g)=∑d|nf(d)g(nd)
  2. f∗(g∗h)=(f∗g)∗hf∗(g∗h)=(f∗g)∗h
  3. f∗(g+h)=f∗g+f∗hf∗(g+h)=f∗g+f∗h
  4. f∗g=g∗f

位向量法子集生成模板 O(n*2^n)

 #include<bits/stdc++.h>
using namespace std;
const int maxn = 2e5+,M = ;
typedef long long ll;
int a[maxn],b[maxn];
void print_subset(int n, int b[],int cur)
{
if(cur==n)
{
for(int i=;i<cur;i++)
{
if(b[i])
printf("%d ",a[i]);
}
printf("\n");
return;
}
b[cur]=;
print_subset(n,b,cur+);
b[cur]=;
print_subset(n,b,cur+);
}
int main()
{
int n;
cin>>n;
for(int i=;i<n;i++)
a[i]=i+;
memcpy(b,a,sizeof(a));
print_subset(n,b,); //传参后会修改b的值 所以copy一个数组
}

AC代码

 #include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5+ ,mod = ;
typedef long long ll;
ll poww(ll a,ll b)
{
ll ans=;
while(b>)
{
if(b&)
ans=(ans*a)%mod;
b=b>>;
a=(a*a)%mod;
}
return ans;
}
int main()
{
int t;
cin>>t;
while(t--)
{
ll q,p,ans=;
int m;
cin>>m;
while(m--)
{
cin>>p>>q;
ll temp=;
temp=(temp*(p-))%mod;
temp=(temp*q)%mod;
temp=(temp*poww(p,q-))%mod;
temp=(temp+poww(p,q))%mod;
ans=ans*temp%mod;
//cout<<ans<<endl;
}
cout<<ans<<endl;
}
}

2017 CCPC 杭州 HDU6265B 积性函数的更多相关文章

  1. bzoj2693--莫比乌斯反演+积性函数线性筛

    推导: 设d=gcd(i,j) 利用莫比乌斯函数的性质 令sum(x,y)=(x*(x+1)/2)*(y*(y+1)/2) 令T=d*t 设f(T)= T可以分块.又由于μ是积性函数,积性函数的约束和 ...

  2. hdu1452 Happy 2004(规律+因子和+积性函数)

    Happy 2004 题意:s为2004^x的因子和,求s%29.     (题于文末) 知识点: 素因子分解:n = p1 ^ e1 * p2 ^ e2 *..........*pn ^ en 因子 ...

  3. HDU 1452 Happy 2004 (逆元+快速幂+积性函数)

    G - Happy 2004 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Subm ...

  4. spoj 3871. GCD Extreme 欧拉+积性函数

    3871. GCD Extreme Problem code: GCDEX Given the value of N, you will have to find the value of G. Th ...

  5. POJ 2480 Longge's problem (积性函数,欧拉函数)

    题意:求∑gcd(i,n),1<=i<=n思路:f(n)=∑gcd(i,n),1<=i<=n可以知道,其实f(n)=sum(p*φ(n/p)),其中p是n的因子.为什么呢?原因 ...

  6. poj 2480 Longge's problem 积性函数

    思路:首先给出几个结论: 1.gcd(a,b)是积性函数: 2.积性函数的和仍然是积性函数: 3.phi(a^b)=a^b-a^(b-1); 记 f(n)=∑gcd(i,n),n=p1^e1*p2^e ...

  7. HDU 1452 Happy 2004(因子和的积性函数)

    题目链接 题意 : 给你一个X,让你求出2004的X次方的所有因子之和,然后对29取余. 思路 : 原来这就是积性函数,点这里这里这里,这里讲得很详细. 在非数论的领域,积性函数指所有对于任何a,b都 ...

  8. bzoj 2693: jzptab 线性筛积性函数

    2693: jzptab Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 444  Solved: 174[Submit][Status][Discus ...

  9. HDU1452Happy 2004(高次幂取模+积性函数+逆元)

    题目意思:2004^x的所有正因数的和(S)对29求余:输出结果: 原题链接 题目解析:解析参照来源:点击打开链接 因子和 6的因子是1,2,3,6; 6的因子和是s(6)=1+2+3+6=12; 2 ...

随机推荐

  1. 使用 JSX 描述 UI 信息

    这一节我们通过一个简单的例子讲解 React.js 描述页面 UI 的方式.把 src/index.js 中的代码改成: import React, { Component } from 'react ...

  2. Activiti工作流和shiro权限管理关系图

  3. hihocoder offer收割编程练习赛11 D 排队接水

    思路: 莫队算法+树状数组. 莫队算法的基本思想是对大量要查询的区间进行离线处理,按照一定的顺序计算,来降低复杂度.概括来说,我们在知道了[l, r]的解,并且可以通过一个较低的复杂度推出[l - 1 ...

  4. [BZOJ1192][HNOI2006]鬼谷子的钱袋 数学

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1192 大水题,把m分成二的幂次方和. #include<cstdio> #in ...

  5. Jenkins .NET项目持续集成配置

    基本步骤 1. 安装并配置MSBUILD 在系统管理->插件管理->添加MSBuild插件 在系统管理->系统设置->找到MSBuild配置部分,配置不同的MSbuild版本 ...

  6. 网页制作常用的CSS知识

    在制作网页中,我们会用到很多CSS的知识,在这里我简单的总结了一些. div    划分区块 ul,li 无序列表(配合划分区块) ol,li 有序列表 a 超链接标签 p 段落标签 h 标题标签 i ...

  7. 安卓 Android 简单数据库(增删改查)

    <Button android:id="@+id/delete_btn" android:layout_width="wrap_content" andr ...

  8. shell脚本的练习

    创建一个以.sh结束的文件. 规则: 文件的头部使用#!/bin/sh 开头   这个是一个标识的作用,告诉使用哪种脚本来执行 echo 用来向命令行来输出的东西

  9. 【计算机网络】3.2 无连接运输:UDP

    第三章第二节 无连接运输:UDP UDP(用户数据报协议,User Datagram Protocol),它只是做了运输层协议能够做的最少工作,除了多路复用和多路分解及一些差错检测外,它几乎没有做任何 ...

  10. 08C#事件

    C#事件 1.2      事件 事件是C#语言内置的语法,可以定义和处理事件,为使用组件编程提供了良好的基础. 1.16.1       事件驱动 Windows操作系统把用户的动作都看作消息,C# ...