hdu1796 How many integers can you find

原题:http://acm.hdu.edu.cn/showproblem.php?pid=1796


用到了容斥原理。看到了很好的算法,直接采用了。

#include<iostream>
#include<cstdio>
#include<cstring>

using namespace std;
typedef __int64 int64;

int n, m, cnt, i, j, x;
int64 ans, a[30];

int64 gcd(int64 a, int64 b)
{
	return b == 0 ? a : gcd(b, a % b);
}

//id 为1 的时候, 计算本身集合的数量。id为2的时候, 计算重叠;
//反复加减, 不计算后面的情况,有点DP的味道。
void DFS(int cur, int64 lcm, int id)//i, a[i], 1
{
	lcm = a[cur] / gcd(a[cur], lcm) * lcm;
	if (id & 1)
		ans += (n - 1) / lcm;     //因为这题并不包含n本身,所以用n-1
	else
		ans -= (n - 1) / lcm;
	for (int i = cur + 1; i < cnt; i++)
		DFS(i, lcm, id + 1);
}

int main()
{
	while (~scanf("%d%d", &n, &m))//~end of file
	{
		cnt = 0;
		ans = 0;
		
		while (m--)
		{
			scanf("%d", &x);
			if (x != 0)    //除0的情况
				a[cnt++] = x;
		}
		
		for (i = 0; i < cnt; i++)
			DFS(i, a[i], 1);
		printf("%d\n", ans);
	}
	return 0;
}



你可能感兴趣的:(编程,C++,c,算法)