又是一道经典题.

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(莫比乌斯反演)的更多相关文章

  1. 【BZOJ2154】Crash的数字表格(莫比乌斯反演)

    [BZOJ2154]Crash的数字表格(莫比乌斯反演) 题面 BZOJ 简化题意: 给定\(n,m\) 求\[\sum_{i=1}^n\sum_{j=1}^mlcm(i,j)\] 题解 以下的一切都 ...

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

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

  3. 【莫比乌斯反演】BZOJ2154 Crash的数字表格

    Description 求sigma lcm(x,y),x<=n,y<=m.n,m<=1e7. Solution lcm没有什么直接做的好方法,用lcm=x*y/gcd转成gcd来做 ...

  4. 【bzoj2154】Crash的数字表格 莫比乌斯反演

    题目描述 今天的数学课上,Crash小朋友学习了最小公倍数(Least Common Multiple).对于两个正整数a和b,LCM(a, b)表示能同时被a和b整除的最小正整数.例如,LCM(6, ...

  5. [复习]莫比乌斯反演,杜教筛,min_25筛

    [复习]莫比乌斯反演,杜教筛,min_25筛 莫比乌斯反演 做题的时候的常用形式: \[\begin{aligned}g(n)&=\sum_{n|d}f(d)\\f(n)&=\sum_ ...

  6. 【bzoj2693】jzptab 莫比乌斯反演+线性筛

    题目描述 输入 一个正整数T表示数据组数 接下来T行 每行两个正整数 表示N.M 输出 T行 每行一个整数 表示第i组数据的结果 样例输入 1 4 5 样例输出 122 题解 莫比乌斯反演+线性筛 由 ...

  7. 【BZOJ2693】jzptab [莫比乌斯反演]

    jzptab Time Limit: 10 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description   求 Input 第一行一个 ...

  8. 莫比乌斯反演/线性筛/积性函数/杜教筛/min25筛 学习笔记

    最近重新系统地学了下这几个知识点,以前没发现他们的联系,这次总结一下. 莫比乌斯反演入门:https://blog.csdn.net/litble/article/details/72804050 线 ...

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

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

随机推荐

  1. River Hopscotch(二分POJ3258)

    River Hopscotch Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 9263 Accepted: 3994 Descr ...

  2. Unix下五种IO模型

    http://blog.chinaunix.net/uid-25324849-id-247813.html 1. I/O模型 Unix下共有五种I/O模型 a. 阻塞I/O b. 非阻塞I/O c. ...

  3. C#中汉诺塔问题的递归解法

    百度测试部2015年10月份的面试题之——汉诺塔. 汉诺塔就是将一摞盘子从一个塔转移到另一个塔的游戏,中间有一个用来过度盘子的辅助塔. 百度百科在此. 游戏试玩在此. 用递归的思想解决汉诺塔问题就是分 ...

  4. 2016年11月7日 星期一 --出埃及记 Exodus 19:23

    2016年11月7日 星期一 --出埃及记 Exodus 19:23 Moses said to the LORD, "The people cannot come up Mount Sin ...

  5. centOS6.5安装SUN-jdk7

    一.下载SUN-JDK1.7.tar.gz文件他 地址:http://www.oracle.com/technetwork/java/javase/downloads/jdk7-downloads-1 ...

  6. java解析密钥格式

    import java.io.StringReader; import org.bouncycastle.asn1.ASN1Sequence; import org.bouncycastle.asn1 ...

  7. memcached完全剖析系列——一、memcached基础

    转自:http://blog.charlee.li/memcached-001/

  8. OpenLayers学习记录(1)

    1.部署自己的服务器 首先下载openlayers的源码.解压后里面有很多内容.我们只需要拷贝目录下的OpenLayer.js.根目录下的lib目录.根目录下的img目录 theme目录 到你网站的o ...

  9. 第二课 android项目结构

  10. SELECT INTO FROM mysql Undeclared variable

    使用SELECT INTO FROM进行数据表和数据的复制时,会提示Error Code: 1327. Undeclared variable: 这是因为mysql 数据库不支持 SELECT INT ...