bzoj2154(莫比乌斯反演)
又是一道经典题.
1.学习了下O(n) 的做法。


//
// main.cpp
// bzoj2154
//
// Created by New_Life on 16/7/7.
// Copyright © 2016年 chenhuan001. All rights reserved.
// #include <iostream>
#include <string.h>
#include <stdio.h>
using namespace std; #define N 10001000
#define MOD 20101009 //--莫比乌斯反演函数--//
//说明:利用线性素数筛选顺便求了个mu
//注释部分为求从区间[1,b]和区间[1,d]中取两个数,互质对数O(n^0.5)
//复杂度:O(n)
int mu[N];
long long sum[N];
int prime[N];
bool mark[N]; void mobus()
{
int pcnt=;
memset(mark,,sizeof(mark));
mu[] = ;
for(int i=;i<N;i++)
{
if(mark[i] == )
{
prime[pcnt++] = i;
mu[i] = -;
}
for(int j=;j<pcnt && i*prime[j]<N;j++)
{
int tmp = i*prime[j];
mark[tmp] = ;
if( i%prime[j] == )
{
mu[tmp] = ;
break;
} mu[tmp] = mu[i]*-;
}
}
for(int i=;i<N;i++)
{
sum[i] += sum[i-]+(long long)mu[i]*i*i;
sum[i] %= MOD;
}
} long long gaobili(long long b,long long d)
{
if(b<=||d<=) return ;
long long m = min(b,d);
long long ans = ;
while(m>=)
{
long long tb = b/( b/m + )+;
long long td = d/( d/m + )+;
//前进的最大位置
long long tm = max(tb,td);
ans += (sum[m]-sum[tm-])*(((b/m+)*(b/m)/)%MOD)%MOD*(((d/m+)*(d/m)/)%MOD)%MOD ;
ans %= MOD;
m = tm-;
}
return ans;
}
//等差数列求和模板,[a1,a1+d,...,an]
long long allsum(long long a1,long long an,long long n)
{
if(n%==)
return (a1+an)*(n/);
else return ((a1+an)/)*n;
} int main(int argc, const char * argv[]) {
mobus();
int b,d;
while(scanf("%d%d",&b,&d)!=EOF)
{
int m = min(b,d);
long long ans = ;
while(m>=)
{
int tb = b/( b/m + )+;
int td = d/( d/m + )+;
//前进的最大位置
int tm = max(tb,td);
ans += allsum(tm,m,m-tm+)%MOD*gaobili(b/m, d/m)%MOD;
ans %= MOD;
m = tm-;
}
cout<<(ans+MOD)%MOD<<endl;
}
return ;
}
/*
4 5 */
2.O(n)预处理,每次查询n^0.5
因为bzoj2693题目找不到了,所以直接用了这题来测试。
这题首先是一个经典的公式变形。 交换连加时变量的位置。

而根据第二个重要的性质,乘性函数的乘除之后还是乘性函数。(加减并不是)
所以后面的连加部分也是乘性函数,这时只需要的单独看只含一个因子的时候,因为里面含有u(i),所以对于D=x^k(x是素因子)只有当i = 1 或 x 时不为0,所以
后面的为x^k(1-x)。这时可以在线性筛选时顺便求出来。
**************************************************************
Problem:
User: chenhuan001
Language: C++
Result: Accepted
Time: ms
Memory: kb
****************************************************************/ #include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <algorithm>
#include <iostream>
using namespace std;
//--莫比乌斯反演函数--//
//说明:利用线性素数筛选顺便求了个mu
//注释部分为求从区间[1,b]和区间[1,d]中取两个数,互质对数O(n^0.5)
//复杂度:O(n)
#define N 10000010
bool mark[N];
int prime[N/]; long long sum[N]; #define MOD 20101009 void mobus()
{
int pcnt=; sum[] = ;
for(int i=;i<N;i++)
{
if(mark[i] == )
{
prime[pcnt++] = i; sum[i] = (long long)i*(-i)%MOD;
}
for(int j=;j<pcnt && i*prime[j]<N;j++)
{
int tmp = i*prime[j];
mark[tmp] = ;
if( i%prime[j] == )
{
sum[tmp] = sum[i]*prime[j];
sum[tmp] %= MOD; break;
}
else
{
sum[tmp] = sum[i]*(sum[prime[j]])%MOD;
} }
}
for(int i=;i<N;i++)
sum[i] = (sum[i]+sum[i-])%MOD;
} long long gaobili(int b,int d)
{
if(b<=||d<=) return ;
long long m = min(b,d);
long long ans = ;
while(m>=)
{
long long tb = b/( b/m + )+;
long long td = d/( d/m + )+;
//前进的最大位置
long long tm = max(tb,td);
ans += (sum[m]-sum[tm-])*(((b/m+)*(b/m)/)%MOD)%MOD*(((d/m+)*(d/m)/)%MOD)%MOD;
ans %= MOD;
m = tm-;
}
return (ans+MOD)%MOD;
} int main()
{
mobus();
int b,d;
while(scanf("%d%d",&b,&d)!=EOF)
{
printf("%d\n",(int)gaobili(b,d));
}
return ;
}
至此mobus大概都刷了一遍,原以为很复杂的东西,其实也不是很难。以后面对的题目可能有更多的公式变形,或许难在找出莫比乌斯模型。但基本的也就是这些方法了。
治好了多年的公式恐惧症。。
bzoj2154(莫比乌斯反演)的更多相关文章
- 【BZOJ2154】Crash的数字表格(莫比乌斯反演)
[BZOJ2154]Crash的数字表格(莫比乌斯反演) 题面 BZOJ 简化题意: 给定\(n,m\) 求\[\sum_{i=1}^n\sum_{j=1}^mlcm(i,j)\] 题解 以下的一切都 ...
- Bzoj2154 Crash的数字表格 乘法逆元+莫比乌斯反演(TLE)
题意:求sigma{lcm(i,j)},1<=i<=n,1<=j<=m 不妨令n<=m 首先把lcm(i,j)转成i*j/gcd(i,j) 正解不会...总之最后化出来的 ...
- 【莫比乌斯反演】BZOJ2154 Crash的数字表格
Description 求sigma lcm(x,y),x<=n,y<=m.n,m<=1e7. Solution lcm没有什么直接做的好方法,用lcm=x*y/gcd转成gcd来做 ...
- 【bzoj2154】Crash的数字表格 莫比乌斯反演
题目描述 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数.例如,LCM(6, ...
- [复习]莫比乌斯反演,杜教筛,min_25筛
[复习]莫比乌斯反演,杜教筛,min_25筛 莫比乌斯反演 做题的时候的常用形式: \[\begin{aligned}g(n)&=\sum_{n|d}f(d)\\f(n)&=\sum_ ...
- 【bzoj2693】jzptab 莫比乌斯反演+线性筛
题目描述 输入 一个正整数T表示数据组数 接下来T行 每行两个正整数 表示N.M 输出 T行 每行一个整数 表示第i组数据的结果 样例输入 1 4 5 样例输出 122 题解 莫比乌斯反演+线性筛 由 ...
- 【BZOJ2693】jzptab [莫比乌斯反演]
jzptab Time Limit: 10 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description 求 Input 第一行一个 ...
- 莫比乌斯反演/线性筛/积性函数/杜教筛/min25筛 学习笔记
最近重新系统地学了下这几个知识点,以前没发现他们的联系,这次总结一下. 莫比乌斯反演入门:https://blog.csdn.net/litble/article/details/72804050 线 ...
- hdu1695 GCD(莫比乌斯反演)
题意:求(1,b)区间和(1,d)区间里面gcd(x, y) = k的数的对数(1<=x<=b , 1<= y <= d). 知识点: 莫比乌斯反演/*12*/ 线性筛求莫比乌 ...
随机推荐
- 【20160924】GOCVHelper 图像增强部分(1)
图像增强是图像处理的第一步.这里集成了一些实际使用过程中有用的函数. //读取灰度或彩色图片到灰度 Mat imread2gray(string path){ Mat sr ...
- flash压力测试
涉及目录: vendor/mediatek/proprietary/bootable/bootloader/preloader/platform/mt6735/src/drivers/inc/dram ...
- 如何实现百度外卖APP个人中心头像"浪"起来的动画效果
作为一个中午下班不肯离开工作岗位且勤奋工作的骚年来说,叫外卖就成了不可或缺的习惯.某日瞬间发现百度外卖的APP波浪效果很是吸引人.相比较其他的外卖APP,颜值略高些.(淘宝也有波浪的效果),遂就思考如 ...
- js监控窗口高度和宽度
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN""http://www.w3.org/T ...
- Java中使用BASE64加密&解密
package com.bao.tools.encryption; import java.io.IOException; import org.junit.Test; import sun.misc ...
- which、whereis、locate、find 命令用法
which.whereis.locate.find 命令用法 大部分转自http://312788172.iteye.com/blog/730280,有修改 我们经常在linux要查找某个文件,但 ...
- 读取视屏文件,保存帧图片为ppm文件
ffmpeg跟sdl的学习过程:一.版本信息:ffmpeg-3.0.2.tar.bz2SDL2-2.0.4.tar.gz二.编译过程:1.ffmgeg的编译:./configure --enable- ...
- freebsd镜像作用和vmware服务开启
第一个是可以引导的光盘,只能引导系统,通常用于网络安装.基本没用.第二个是系统光盘的第一张.用这张就可以安装一个基本的系统.其他的软件,在系统安装完之后安装.第三个是系统盘的DVD版本.包括的软件比上 ...
- SAP、BW 权限控制设置
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- JavaScript经典代码【二】【javascript判断用户点了鼠标左键还是右键】
IE 下 onMouseDown 事件有个 events.button 可以返回一个数值,根据数值判断取得用户按了那个鼠标键 events.button==0 默认.没有按任何按钮. events.b ...