您的位置:首页 > 其它

NOI2010 能量采集

2011-08-01 14:21 211 查看
#include <cstdio>
#include <iostream>
using namespace std;
const int MAXN = 100000 + 123;
long long cnt[MAXN];
int main()
{
long long n, m;
cin >> n >> m;
int t = n > m ? m : n;

for(int i = 1; i <= t; i++) cnt[i] = (n / i) * (m / i);

long long ans = 0;

for(int i = t; i >= 1; i--)
{
for(int j = 2; j * i <= t; j++)
cnt[i] -= cnt[j * i];
ans += cnt[i] * i;
}

//printf("%I64d\n", 2 * ans - (long long)n * m);
ans = 2 * ans - n * m;
cout << ans << endl;
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  2010 include