标签:
容斥原理:在计数时,必须注意无一重复,无一遗漏。为了使重叠部分不被重复计算,人们研究出一种新的计数方法,这种方法的基本思想是:先不考虑重叠的情况,把包含于某内容中的所有对象的数目先计算出来,然后再把计数时重复计算的数目排斥出去,使得计算的结果既无遗漏又无重复,这种计数的方法称为容斥原理。
LL Q[100010],factor[110],num;
//Q数组存放的就是右边边各项的因子数以及正负情况,factor[]存放对应对象的数目,num为有几个对象
void Divid(LL n) //n的素因子分解,得到每项素因子的个数
{
num = 0;
for(LL i = 2; i*i <= n; ++i)
{
if(n%i==0)
{
while(n%i==0)
n /= i;
factor[num++] = i;
}
}
if(n != 1)
factor[num++] = n;
}
LL solve(LL n) //容斥定理,求
{
LL k,t,ans;
t = ans = 0;
Q[t++] = -1;
for(LL i = 0; i < num; ++i)
{
k = t;
for(LL j = 0; j < k; ++j)
Q[t++] = -1*Q[j]*factor[i];
}
//A∪B∪C = A+B+C - A∩B - B∩C - C∩A + A∩B∩C
//Q数组存放的就是A∪B∪C右边边各项的因子数以及正负情况。
for(LL i = 1; i < t; ++i)
ans += n/Q[i];
//n/Q[i]累加起来就是A∪B∪C
return ans;
}
标签:
原文地址:http://blog.csdn.net/lianai911/article/details/45565645