题意:定义一个数K,最小质因数形式为K = a*b*c形式(如12 = 2*2*3),相同只取一个(所以12只能取2,3两个,既F[12]=2)给L,R区间,找出区间内最大的F[x](L<=x<=R).



思路:先打素数表,然后枚举1000000内全部数,因为可能值只能为2,3,5,7,11,13,17这7个数,所以arr数组存放每个数对应的值的个数,然后用dp数组来表示下标为i并且小于i的所有数为j值的个数,最后只要从给定的两个区间做一次值比较即可。

#include <stdio.h>
#include <iostream>
#define MAX 1000000+50
#define N 1000000
using namespace std;
int value[MAX],prime[MAX];
int dp[MAX][9];
void Isprime()
{
int flag = 0;
prime[2]=1;
for(int i=3; i<=N; i++)
{
if(i%2==0)
flag=1;
else
for(int j=3; j*j<=i; j=j+2)
if(i%j==0)
{
flag = 1;
break;
}
if(flag==0)
prime[i]=1;
flag=0;
}
}
void getValue()
{
for(int i = 2; i<=N; i++) //通过枚举全部数,一层一层递加上去,最后可以得到value存放的为1-1000000数对应不重复质因数的个数
if(prime[i])
for(int j=i; j<=N; j+=i)
value[j]++;
// cout<<value[j]<<" ";
// cout<<endl;
}
void solve()
{
for(int i=2; i<=N; i++)
dp[i][value[i]]++; //初始化dp
//for(int i = 2;i<=n;i++)
//{
// cout<<dp[i][value[i]]<<" ";
//}
for(int i=2; i<=N; i++) //枚举所有数,并且因为只有7个可能值,所以用dp来存放7个对应值的个数
for(int j=1; j<8; j++)
dp[i][j]+=dp[i-1][j];
//if(i==99)
// for(int j = 1;j<8;j++)
// cout<<dp[i][j]<<" ";
}
void init()
{
Isprime();
getValue();
solve();
}
int main()
{
init();
int T,i,j,L,R,flag;
scanf("%d",&T);
while(T--)
{
flag=-1;
scanf("%d%d",&L,&R);
for(j=2; j<8; j++) //j值只能为7个数
if(dp[R][j]-dp[L-1][j]>=2)//dp存放的为R下标以内值为j的个数,所以相减后可得区间内对应j值的个数,然后只要去最大的就行
flag=max(flag,j);
printf("%d\n",flag);
}
return 0;
}

HDU5317的更多相关文章

  1. hdu5317 RGCDQ 统计

    // hdu5317 RGCDQ // // 题目大意: // // 给定一个闭区间[l,r],定义f(x)是x的不同的质因子的个数 // 比方: 12 = 2 * 2 * 3,是两种.所以f(x) ...

  2. 解题报告 之 HDU5317 RGCDQ

    解题报告 之 HDU5317 RGCDQ Description Mr. Hdu is interested in Greatest Common Divisor (GCD). He wants to ...

  3. hdu5317 RGCDQ (质因子种数+预处理)

    RGCDQ 题意:F(x)表示x的质因子的种数.给区间[L,R],求max(GCD(F(i),F(j)) (L≤i<j≤R).(2<=L < R<=1000000) 题解:可以 ...

  4. HDU-5317

    RGCDQ Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Submi ...

  5. HDU-5317 RGCDQ ,暴力打表!

    RGCDQ 暴力水题,很可惜比赛时没有做出来,理清思路是很简单的. 题意:定义f(i)表示i的素因子个数,给你一段区间[l,r],求max_gcd(f(i),f(j)).具体细节参考题目. 思路:数据 ...

  6. hdu5317 RGCDQ

    Problem Description Mr. Hdu is interested in Greatest Common Divisor (GCD). He wants to find more an ...

随机推荐

  1. java导入导出excel常用操作小结及简单示例

    POI中常用设置EXCEL的操作小结: 操作excel如下 HSSFWorkbook wb = new HSSFWorkbook();  //创建一个webbook,对应一个Excel文件 HSSFS ...

  2. 转:PHP如何阻止用户上传成人照片或者裸照

    原文来自于:http://www.hackbase.com/tech/2014-10-12/69367.html 当前,网络淫秽色情信息屡禁不止.屡打不绝,严重危害未成年人身心健康,严重败坏社会风气, ...

  3. J2EE开源项目

    这篇文章写在我研究J2SE.J2EE近三年后.前3年我研究了J2SE的Swing.Applet.Net.RMI.Collections.IO.JNI……研究了J2EE的JDBC.Sevlet.JSP. ...

  4. Arctic Network

    poj2349:http://poj.org/problem?id=2349 题意:有卫星电台的城市之间可以任意联络.没有卫星电台的城市只能和距离小于等于D的城市联络.告诉你卫星电台的个数S,让你求最 ...

  5. A Knight's Journey(dfs)

    Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 25950   Accepted: 8853 Description Back ...

  6. 使用ICSharpCode.SharpZipLib.Zip实现压缩与解压缩

    使用开源类库ICSharpCode.SharpZipLib.Zip可以实现压缩与解压缩功能,源代码和DLL可以从http://www.icsharpcode.net/OpenSource/SharpZ ...

  7. wpa_cli与wpa_supplicant的交互命令

    1)通过adb命令行,可以直接打开supplicant,从而运行wpa_cli,可以解决客户没有显示屏而无法操作WIFI的问题,还可以避免UI的问题带到driver.进一步来说,可以用在很多没有键盘输 ...

  8. 数据结构(RMQ):POJ 3624 Balanced Lineup

    Balanced Lineup   Description For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always li ...

  9. 将汉字转化为拼音,正则表达式和得到汉字的Unicode编码

    一:上图,不清楚的看代码注解,很详细了 二:具体代码 窗体代码 using System; using System.Collections.Generic; using System.Compone ...

  10. Nodejs in Visual Studio Code 07.学习Oracle

    1.开始 Node.js:https://nodejs.org OracleDB: https://github.com/oracle/node-oracledb/blob/master/INSTAL ...