博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【洛谷2522】[HAOI2011] Problem b(莫比乌斯反演)
阅读量:4682 次
发布时间:2019-06-09

本文共 948 字,大约阅读时间需要 3 分钟。

大致题意:\(\sum_{x=a}^b\sum_{y=c}^d[gcd(x,y)==k]\)

关于另一道题目

在看这篇博客之前,如果你做过一道叫做的题目,那么此题就很简单了。

如果没做过,还是推荐你先去做一下吧。

解题思路

做完了上面提到的那题,或许对这题你就有一个很显然的想法了。

差分

其实,上面那题就是此题\(a=c=1\)的特殊版本。

因此,如果令\(ans_{i,j}=\sum_{x=1}^i\sum_{y=1}^j[gcd(x,y)==k]\),则:

\[answer=ans_{b,d}-ans_{a-1,d}-ans_{b,c-1}+ans_{a-1,c-1}\]

于是就水过了(相当于双倍经验啊)。

代码

#include
#define max(x,y) ((x)>(y)?(x):(y))#define min(x,y) ((x)<(y)?(x):(y))#define uint unsigned int#define LL long long#define ull unsigned long long#define swap(x,y) (x^=y,y^=x,x^=y)#define abs(x) ((x)<0?-(x):(x))#define INF 1e9#define Inc(x,y) ((x+=(y))>=MOD&&(x-=MOD))#define ten(x) (((x)<<3)+((x)<<1))#define N 50000using namespace std;int X1,Y1,X2,Y2,k;class FIO{ private: #define Fsize 100000 #define tc() (FinNow==FinEnd&&(FinEnd=(FinNow=Fin)+fread(Fin,1,Fsize,stdin),FinNow==FinEnd)?EOF:*FinNow++) #define pc(ch) (FoutSize

转载于:https://www.cnblogs.com/chenxiaoran666/p/Luogu2522.html

你可能感兴趣的文章
【问题和解决】python中nltk与nltk_contrib的关系
查看>>
闭包的探索
查看>>
内存泄漏
查看>>
编程之美 2.12 快速寻找满足条件的两个数 解法三证明 (算法导论 第二版 2.3-7 在n个元素的集合S中找到两个和为x的元素)...
查看>>
open_basedir restriction in effect,解决php引入文件权限问题
查看>>
微信小程序获取用户信息解密AES并且注意如何获取unionid
查看>>
JavaScript设计模式----1
查看>>
Qt实现半透明遮罩效果
查看>>
erlang调优方法
查看>>
Mysql linux -N命令
查看>>
daily scrum 12.5
查看>>
linux-ftp install
查看>>
NetXray
查看>>
局域网基本工作原理
查看>>
让历史告诉我们未来
查看>>
UVa540 Team Queue
查看>>
android 练习之路 (八)
查看>>
tp5 中 model 的聚合查询
查看>>
android wear开发之:增加可穿戴设备功能到通知中 - Adding Wearable Features to Notifications...
查看>>
压缩文件函数库(转载)
查看>>