HDU1286

本文详细介绍了作者在解决复杂算法问题时遇到的挑战,包括初次使用欧拉函数算法遇到WA的情况,以及后续通过打表和优化素数打表方法最终AC的过程。文中提供了两个关键代码段,帮助读者理解如何有效解决问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

本题思路明确,应该是一道水题;但是却让我WA了1次TIM了1次,郁闷ing;第一次看了一下是欧拉公式我自己现在还是认为可以解决但是却WA了,不找到哪位大牛可以指导下。第二次,就用打表的但是调用了最大公约数超时了;后来想到了素数打表的方法,过了109MS。

 

下面是WA的欧拉函数算法,希望大牛指点

#include"stdio.h"
int eular(int n)
{
	int i,res=1;
	for(i=2;i*i<n;i++)
	{
		if(n%i==0)
		{
			res*=i-1;
			n/=i;
			while(n%i==0)
			{
				res*=i;
				n/=i;
			}
		}
	}
	if(n>1)
		res*=n-1;
	return res;
}
int main()
{
	int n,m;
	scanf("%d",&n);
	while(n--)
	{
		scanf("%d",&m);
		printf("%d\n",eular(m));
	}
	return 0;
}


 

这个是AC的代码:

#include"stdio.h"
#include"string.h"
int d[32770];
int main()
{
	int t,n,i,j;
	scanf("%d",&t);
	while(t--)
	{
		memset(d,0,sizeof(d));
		scanf("%d",&n);
		for(i=2;i<n;i++)
			if(n%i==0&&d[i]==0)
			{
				for(j=i;j<n;j+=i)
				d[j]=1;
			}
			int count=0;
			for(i=1;i<n;i++)
				if(d[i]==0)
					count++;
			printf("%d\n",count);
	}
	return 0;
}


 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值