Description

Input

输入仅有一行。

第一行仅有两个正整数N,M 和一个实数 x。 

Output

输出共1行,由亍结果过大,所以请输出上式对998244353 取模的结果。

Sample Input

2 3 1

Sample Output

7

题解:

(吐槽:博客园的数学公式好慢……)

  先%一发po姐……不看题解根本没思路啊……

$\sum_{n=1}^{N}\sum_{m=1}^{M}\sum_{k=0}^{m-1}\lfloor\frac{nk+x}{m} \rfloor$

$我们先考虑后半部分$

$\;\;\;\,\sum_{k=0}^{m-1}\lfloor\frac{nk+x}{m} \rfloor$

$=\sum_{k=0}^{m-1}\lfloor\frac{nk-nk\,\bmod\, m+x+nk\,\bmod\,m}{m} \rfloor$

$=\sum_{k=0}^{m-1}\lfloor\frac{nk\,\bmod\,m+x}{m} \rfloor+\sum_{k=0}^{m-1}\frac{nk-nk\,\bmod\,m}{m}$

$考虑前半部分,同时设d=(n,m)$

$\;\;\,\;\sum_{k=0}^{m-1}\lfloor\frac{nk\,\bmod\,m+x}{m} \rfloor$

$=d\sum_{k=0}^{\frac{m}{d}-1}\lfloor\frac{kd}{m} \rfloor$

证明:首先设$(n,m)==d$,那么对同余方程$\;\;xn\equiv kd(\bmod m),k\in[0,\frac{m}{d}-1]$,我们知道一定存在整数解$x$,满足该式,同时有由于方程多解,且每个解的间隔应为$\frac{m}{d}$,所以$kd$在$\sum_{k=0}^{m-1}nk\,\bmod\,m$中共出先了$d$次

(我们仿照最开始将nk拆离的方法)

$=d\sum_{k=0}^{\frac{m}{d}-1}\lfloor\frac{kd+x\,\bmod\,m+x-x\,\bmod\,m}{m}\rfloor$

$=d(\sum_{k=0}^{\frac m d-1}\lfloor \frac{kd+x\,\bmod\,m}m \rfloor+\sum_{k=0}^{\frac m d-1} \frac{x-x\,\bmod\,m}m) $

$我们知道kd<m\;\;\;x\bmod m<m $

$=d(\sum_{k=0}^{\frac m d-1}[kd\geq m-x\bmod m]+\frac md\frac{x-x\,\bmod\,m}m) $

$=d(\sum_{k=0}^{\frac md-1}[\,k\geq\lceil \frac{m-x\,\bmod\,m}{d}\rceil\,]+\frac{x-x\,\bmod\,m}{d})$

$=d(\lfloor\frac{x\,\bmod\,m}{m}\rfloor+\lfloor \frac xd\rfloor-\lfloor \frac{x\,\bmod\,m}{d}\rfloor)$

$=d\lfloor \frac xd\rfloor$

我们再来看最开始另外两项

$1.\sum_{k=0}^{m-1}\frac{nk}m=\frac nm \frac{m(m-1)}2=\frac{nm-n}{2}$

$2.\sum_{k=0}^{m-1}\frac{nk\,mod\,m}m(我们同样用到d)$

$=d\sum_{k=0}^{\frac md-1}\frac{dk}m=\frac {d^{2}}m\frac{\frac md(\frac md-1)}{2}=\frac{m-d}{2}$

$Ans=\sum_{n=1}^{N}\sum_{m=1}^{M}(d\lfloor\frac xd \rfloor+\frac {d+nm-n-m}2)$

$\;\;\;\;\;\;\;\,=\frac 12\sum_{n=1}^{N}\sum_{m=1}^{M}(2d\lfloor\frac xd \rfloor+ d+nm-n-m)$

$设S(n)=\frac{n(n+1)}2$

$\;\;\;\;\;\;\;\,=\frac 12(\sum_{n=1}^{N}\sum_{m=1}^{M}(2d\lfloor\frac xd \rfloor+ d)+S(N)S(M)-MS(N)-NS(M))$

$\;\;\;\;\;\;\;\,=\frac 12(\,\sum_{d=1}^{min(N,M)}(2d\lfloor\frac xd \rfloor+ d)\sum_{t=1}^{\min(\lfloor\frac Nd\rfloor,\lfloor\frac Md\rfloor)}\mu(t)\lfloor \frac N{dt}\rfloor\lfloor \frac M{dt}\rfloor\;+S(N)S(M)-MS(N)-NS(M)\,)$

对于后面我们O(1)求出即可,前面枚举每一个d带入计算即可。

时间复杂度$\sum_{i=1}^{n}\sqrt \frac ni\approx\sqrt n\int_{1}^{n}x^{-0.5}dx=2n-2\sqrt n $

代码:

 /**************************************************************
Problem: 4174
User: Troywar
Language: C++
Result: Accepted
Time:964 ms
Memory:5100 kb
****************************************************************/ #include<cstdio>
#include<iostream>
using namespace std;
typedef long long ll;
const ll mod=;
inline ll powmod(ll a, ll b){
ll ans=;
while(b){
if(b&) ans=ans*a%mod;
a=a*a%mod;
b>>=;
}return ans;
}
inline ll S(int x){
return 1LL*x*(x+)/%mod;
}
const int N=+;
short miu[N];
bool vis[N];
int sum[N],prim[N/],num;
double x;
inline void init (){
miu[]=sum[]=;
for(int i=;i<N;i++){
if(!vis[i]){
miu[i]=-;
prim[++num]=i;
}for(int j=;i*prim[j]<N;j++){
vis[i*prim[j]]=true;
if(i%prim[j]==){
miu[i*prim[j]]=;
break;
}miu[i*prim[j]]=-miu[i];
}
sum[i]=sum[i-]+miu[i];
} }
inline ll get_sum(int n,int m){
ll ans=;
for(int i=,pos;i<=n;i=pos+){
pos=min(n/(n/i),m/(m/i));
ans+=1LL*(sum[pos]-sum[i-])*(n/i)%mod*(m/i)%mod;
ans%=mod;
}
return (ans+mod)%mod;
}
int n,m;
int main(){
scanf("%d%d%lf",&n,&m,&x);
init();
ll ans=S(n)*S(m)%mod-S(n)*m%mod-S(m)*n%mod;
ans=(ans%mod+mod)%mod;
if(n>m) n^=m^=n^=m;
for(int i=;i<=n;i++){
ans+=(2ll*i*(ll)(x/i)+i)%mod*get_sum(n/i,m/i)%mod;
ans%=mod;
}
ans*=powmod(,mod-);
ans%=mod;
printf("%lld\n",(ans+mod)%mod);
}
/*
15674 234561 126.156
*/

【bzoj4174】tty的求助 莫比乌斯反演的更多相关文章

  1. BZOJ 4174 tty的求助 莫比乌斯反演

    题目大意:求∑Nn=1∑Mm=1∑m−1k=0⌊nk+xm⌋ mod 998244353 如果n和m都已经确定了.如今要求这坨玩应: ∑m−1k=0⌊nk+xm⌋ =∑m−1k=0(⌊nk%m+xm⌋ ...

  2. hdu1695 GCD(莫比乌斯反演)

    题意:求(1,b)区间和(1,d)区间里面gcd(x, y) = k的数的对数(1<=x<=b , 1<= y <= d). 知识点: 莫比乌斯反演/*12*/ 线性筛求莫比乌 ...

  3. BZOJ 2154: Crash的数字表格 [莫比乌斯反演]

    2154: Crash的数字表格 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 2924  Solved: 1091[Submit][Status][ ...

  4. BZOJ2301: [HAOI2011]Problem b[莫比乌斯反演 容斥原理]【学习笔记】

    2301: [HAOI2011]Problem b Time Limit: 50 Sec  Memory Limit: 256 MBSubmit: 4032  Solved: 1817[Submit] ...

  5. Bzoj2154 Crash的数字表格 乘法逆元+莫比乌斯反演(TLE)

    题意:求sigma{lcm(i,j)},1<=i<=n,1<=j<=m 不妨令n<=m 首先把lcm(i,j)转成i*j/gcd(i,j) 正解不会...总之最后化出来的 ...

  6. 莫比乌斯函数筛法 & 莫比乌斯反演

    模板: int p[MAXN],pcnt=0,mu[MAXN]; bool notp[MAXN]; void shai(int n){ mu[1]=1; for(int i=2;i<=n;++i ...

  7. 【BZOJ-2440】完全平方数 容斥原理 + 线性筛莫比乌斯反演函数 + 二分判定

    2440: [中山市选2011]完全平方数 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2371  Solved: 1143[Submit][Sta ...

  8. POI2007_zap 莫比乌斯反演

    题意:http://hzwer.com/4205.html 同hdu1695 #include <iostream> #include <cstring> #include & ...

  9. hdu.5212.Code(莫比乌斯反演 && 埃氏筛)

    Code Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Submi ...

随机推荐

  1. poi excel 常用操作

    基本 Workbook wb= new HSSFWorkbook(); Sheet sheet = wb.createSheet("sheetName"); Row row = s ...

  2. JavaScript设计模式之一Interface接口

    如何用面向对象的思想来写JavaScript,对于初学者应该是比较难的,我们经常用的JQuery其实也是用面向对象的思想去封装的,今天我们来看看如何在Javascript中用Interface,在C# ...

  3. JavaScript中对象数组 作业

    var BaiduUsers = [], WechatUsers = []; var User = function(id, name, phone, gender, age, salary) { t ...

  4. 使用可变对象作为python函数默认参数引发的问题

    写python的都知道,python函数或者方法可以使用默认参数,比如 1 def foo(arg=None): 2 print(arg) 3 4 foo() 5 6 foo("hello ...

  5. CSS position 笔记+实验

    目录: 1.static 2.relative 3.absolute 4.fixed 5.实验:static, relative, absolute中,父元素-子元素高度关系 6.z-index 7. ...

  6. Modelsim中使用TCL脚本编写do文件实现自动化仿真

    通常我们使用Modelsim进行仿真,是通过图形界面点点点来进行操作,殊不知Modelsim完美支持TCL脚本语言及批处理命令do文件.简单来说就是从你修改完代码后到你重新编译把需要的信号拉出来查看, ...

  7. 【转】学习FFmpeg API – 解码视频

    ffmpeg是编解码的利器,用了很久,以前看过dranger 的教程,非常精彩,受益颇多,是学习ffmpeg api很好的材料.可惜的是其针对的ffmpeg版本已经比较老了,而ffmpeg的更新又很快 ...

  8. Retrofit 2.0 超能实践,完美支持Https传输

    http://blog.csdn.NET/sk719887916/article/details/51597816 前阵子看到圈子里Retrofit 2.0,RxJava(Android), OkHt ...

  9. 我写的python代码的规则

    1.Python文件的命名: 采用每个单词的首字母大写,不使用下划线 2.Python类的命名: 采用每个单词的首字母大写,不使用下划线 3.Python包名的命名:采用每个单词都是小写,不使用下划线 ...

  10. 原生Feign使用详解

    一,简介 Feign使得 Java HTTP 客户端编写更方便.Feign 灵感来源于Retrofit.JAXRS-2.0和WebSocket.Feign最初是为了降低统一绑定Denominator到 ...