【BZOJ3601】一个人的数论 高斯消元+莫比乌斯反演
【BZOJ3601】一个人的数论
.jpg)
题解:本题的做法还是很神的~

那么g(n)如何求呢?显然它的常数项=0,我们可以用待定系数法,将n=1...d+1的情况代入式子中解方程,有d+1个方程和d+1个未知数,直接高斯消元解出ai即可。
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
typedef long long ll;
const ll P=1000000007;
int d,n;
ll ans;
ll v[110][110],pa[1010],pb[1010];
ll pm(ll x,ll y)
{
ll z=1;
while(y)
{
if(y&1) z=z*x%P;
x=x*x%P,y>>=1;
}
return z;
}
void gauss()
{
int i,j,k;
for(i=1;i<=d+1;i++)
{
for(j=i;j<=d+1;j++) if(v[j][i]) break;
if(i!=j) for(k=i;k<=d+2;k++) swap(v[i][k],v[j][k]);
ll tmp=pm(v[i][i],P-2);
for(k=i;k<=d+2;k++) v[i][k]=v[i][k]*tmp%P;
for(j=1;j<=d+1;j++) if(i!=j)
{
tmp=v[j][i];
for(k=i;k<=d+2;k++) v[j][k]=(v[j][k]-tmp*v[i][k]%P+P)%P;
}
}
}
int main()
{
scanf("%d%d",&d,&n);
int i,j;
for(i=1;i<=d+1;i++)
{
for(j=1;j<=d+1;j++) v[i][j]=pm(i,j);
for(j=1;j<=i;j++) v[i][d+2]=(v[i][d+2]+pm(j,d))%P;
}
gauss();
for(i=1;i<=n;i++) scanf("%lld%lld",&pa[i],&pb[i]);
for(i=1;i<=d+1;i++)
{
ll tmp=1;
for(j=1;j<=n;j++)
{
tmp=tmp*(pm(pa[j],pb[j]*i)-pm(pa[j],d+(pb[j]-1)*i)%P+P)%P;
}
ans=(ans+tmp*v[i][d+2]%P)%P;
}
printf("%lld",ans);
return 0;
}//3 2 2 1 5 1
【BZOJ3601】一个人的数论 高斯消元+莫比乌斯反演的更多相关文章
- BZOJ3601 一个人的数论  【数论 + 高斯消元】
		
题目链接 BZOJ3601 题解 挺神的 首先有 \[ \begin{aligned} f(n) &= \sum\limits_{x = 1}^{n} x^{d} [(x,n) = 1] \\ ...
 - HDU 5833 Zhu and 772002 (数论+高斯消元)
		
题目链接 题意:给定n个数,这n个数的素因子值不超过2000,从中取任意个数使其乘积为完全平方数,问有多少种取法. 题解:开始用素筛枚举写了半天TLE了,后来队友说高斯消元才想起来,果断用模板.赛后又 ...
 - BZOJ3601. 一个人的数论(狄利克雷卷积+高斯消元)及关于「前 $n$ 个正整数的 $k$ 次幂之和是关于 $n$ 的 $k+1$ 次多项式」的证明
		
题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=3601 题解 首先还是基本的推式子: \[\begin{aligned}f_d(n) &a ...
 - 【bzoj3601】一个人的数论 莫比乌斯反演+莫比乌斯函数性质+高斯消元
		
Description Sol 这题好难啊QAQ 反正不看题解我对自然数幂求和那里是一点思路都没有qwq 先推出一个可做一点的式子: \(f(n)=\sum_{k=1}^{n}[(n,k)=1]k^d ...
 - [bzoj3601] 一个人的数论 [莫比乌斯反演+高斯消元]
		
题面 传送门 思路 这题妙啊 先把式子摆出来 $f_n(d)=\sum_{i=1}^n[gcd(i,n)==1]i^d$ 这个$gcd$看着碍眼,我们把它反演掉 $f_n(d)=\sum_{i=1}^ ...
 - 【bzoj3601】一个人的数论  莫比乌斯反演+高斯消元
		
题目描述 题解 莫比乌斯反演+高斯消元 (前方高能:所有题目中给出的幂次d,公式里为了防止混淆,均使用了k代替) #include <cstdio> #include <cstrin ...
 - BZOJ-1013   球形空间产生器sphere     高斯消元+数论推公式
		
1013: [JSOI2008]球形空间产生器sphere Time Limit: 1 Sec Memory Limit: 162 MB Submit: 3662 Solved: 1910 [Subm ...
 - 【BZOJ-3143】游走     高斯消元 + 概率期望
		
3143: [Hnoi2013]游走 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2264 Solved: 987[Submit][Status] ...
 - 【BZOJ-3270】博物馆      高斯消元 + 概率期望
		
3270: 博物馆 Time Limit: 30 Sec Memory Limit: 128 MBSubmit: 292 Solved: 158[Submit][Status][Discuss] ...
 
随机推荐
- 转载——Java与WCF交互(一)补充:用WSImport生成WSDL的Java客户端代码
			
在<Java与WCF交互(一):Java客户端调用WCF服务>一文中,我描述了用axis2的一个Eclipse控件生成WCF的Java客户端代理类,后来有朋友建议用Xfire.CXF,一直 ...
 - AC日记——[Sdoi2010]星际竞速 bzoj 1927
			
1927 思路: 连边,拆点: 每个点拆成i,i+n,都向t连边: i到t表示高速模式,i+n到t表示跳跃模式: 然后读入路径,如果u>v,则交换u,v: u向v+n连边: spfa跑最小费用: ...
 - 对动态规划(Dynamic Programming)的理解:从穷举开始(转)
			
转自:http://janfan.cn/chinese/2015/01/21/dynamic-programming.html 动态规划(Dynamic Programming,以下简称dp)是算法设 ...
 - Codeforces 546D Soldier and Number Game(数论)
			
类似筛素数的方法……求出前缀和.然后直接O(1)回答即可. #include <bits/stdc++.h> using namespace std; #define rep(i,a,b) ...
 - Wildcard Matching - LeetCode
			
Implement wildcard pattern matching with support for '?' and '*'. '?' Matches any single character. ...
 - inux 下的/etc/profile、/etc/bashrc、~/.bash_profile、~/.bashrc 文件的作用
			
/etc/bashrc:为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取. ~/.bash_profile:每个用户都可使用该文件输入专用于自己使用的sh ...
 - setTimeout改变this指向(****************************************)
			
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
 - Using Blocks in iOS 4: Designing with Blocks
			
In the first part of this series, we learned how to declare and call basic Objective-C blocks. The m ...
 - Picasso,Glide,Fresco那个好?
			
前言:在Android开发中,图片加载OOM一直困扰着很多开发者,在各种不合理的设计之下也容易导致图片加载OOM的问题,目前开源的比较常用的图片加载库也很多,比如老牌的UIL,Volley,AQuer ...
 - hibernate uuid