POINT:
要求所有的元素都不是正整数N的因数。
那么求这个数 存在因素在集合中。用容斥做。
然后减掉即可。
wa点,会爆LL。
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <string>
#include <map>
using namespace std;
#define LL unsigned long long
const int maxn = 1e2+3;
LL l,r,k;
LL a[maxn];
LL sum=0;
void dfs(LL x,LL now,LL c)
{
if(x>r) return;//x会爆LL
if(c&1){
sum+=r/x-(l-1)/x;
}else{
sum-=r/x-(l-1)/x;
}
for(LL i=now+1;i<=k;i++){
dfs(x*a[i],i,c+1);
}
}
int main()
{
while(~scanf("%llu%llu%llu",&l,&r,&k)){
sum=0;
for(LL i=1;i<=k;i++)
scanf("%llu",&a[i]);
for(LL i=1;i<=k;i++)
dfs(a[i],i,1);
printf("%llu\n",(r-l+1)-sum);
}
}