HDU 2574 Hdu Girls' Day

本文提供了一种解决HDU 2574问题的方法,通过筛选1到1<<16之间的素数来判断是否能分解为多个素数的乘积,并找出最多素数因子的名字。

地址:http://acm.hdu.edu.cn/showproblem.php?pid=2574

思路1:素数有关  ,不太懂。。。

思路2:因为 大于 1 << 16 的和数都能用 1 -- 1<<16 之间的素数表示, 不能表示的肯定是 素数了, 所以处理 1-- 1<<16之间的素数就可以了.

不过貌似这题的数据很弱没有大于 1 << 16 的素数.

 1 #include<stdio.h>
 2  #include<string.h>
 3  #include<math.h>
 4  int prime[1000000] = {0};
 5  
 6  int main()
 7  {
 8      int T,i,j,n,num,max,k;
 9      char name[100],s[100];
10      prime[0]=prime[1]=1;
11      for(i = 2; i <1000; i++)
12          for(j = i * i; j <1000000; j+= i)
13              prime[j] = 1;
14      scanf("%d",&T);
15      while(T--)
16      {
17          max=-1;
18          scanf("%d",&n);
19          while(n--)
20          {
21              k=0;
22              scanf("%s%d",name,&num);
23              for(i=2;i<=num;++i)
24              {
25                  if(prime[i])
26                      continue;
27                  if(num%i==0)
28                  {
29                      ++k;
30                      num/=i;
31                  }
32              }
33              if(max<k)
34              {
35                  max=k;
36                  strcpy(s,name);
37              }
38              else if(max&&max==k)
39              {
40                  if(strcmp(s,name)>0)
41                      strcpy(s,name);
42              }
43          }
44          printf("%s\n",s);
45      }
46      return 0;
47  }

转载于:https://www.cnblogs.com/mycapple/archive/2012/08/14/2637547.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值