码迷,mamicode.com
首页 > 其他好文 > 详细

Light OJ 1278 Sum of Consecutive Integers N拆分成连续整数和

时间:2014-06-08 15:34:09      阅读:295      评论:0      收藏:0      [点我收藏+]

标签:c   class   blog   code   a   http   

题目来源:Light OJ 1278 Sum of Consecutive Integers

题意:N拆分成连续整数和的方案数

思路:奇因数的个数

#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
//筛素数 
const int maxn = 10000010;
bool vis[maxn];
int prime[1000000];

int sieve(int n)
{
	memset(vis, 0, sizeof(vis));
	vis[0] = vis[1] = 1;
	int c = 0;
	for(int i = 2; i <= n; i++)
		if(!vis[i])
		{
			prime[c++] = i;
			for(int j = 2*i; j <= n; j += i)
				vis[j] = 1;
		}
	return c;
}


int main()
{
	int c = sieve(10000000);
	int cas = 1;
	int T;
	scanf("%d", &T);
	while(T--)
	{
		long long n, ans = 1;
		scanf("%lld", &n);
		while(n%2 == 0)
			n /= 2;
		for(int i = 0; i < c && (long long)prime[i]*prime[i] <= n; i++)
		{
			if(prime[i] > n)
				break;
			if(n % prime[i] == 0)
			{
				long long sum = 1;
				while(n % prime[i] == 0)
				{
					sum++;
					n /= prime[i];
				}
				ans *= sum;
			}
		}
		if(n > 1 && (n&1))
			ans *= 2;
		printf("Case %d: %lld\n", cas++, ans-1);
	}
	return 0;
}


Light OJ 1278 Sum of Consecutive Integers N拆分成连续整数和,布布扣,bubuko.com

Light OJ 1278 Sum of Consecutive Integers N拆分成连续整数和

标签:c   class   blog   code   a   http   

原文地址:http://blog.csdn.net/u011686226/article/details/28672983

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!