题意:定义一个数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. 关于 self 和 super 在oc 中 的疑惑 与 分析

    关于 self 和 super 在oc 中 的疑惑 与 分析   面试一定都是很注重 基础的,不管高级还是初级. 虽然基础好跟基础不好都可以写 代码,网上那么多资料.  区分高低也就是研究的深度和广度 ...

  2. 单例-b

    这个比较老了,是mrc 里面的 此例以模仿Apple官方文档的单例写出来的.但是一直有一个非常不明白的地方,就是alloc与allocWithZone:的重载中,为什么要return [[self c ...

  3. hbase 0.96 单机伪分布式配置文件及遇到的问题 find命令

    http://www.apache.org/dyn/closer.cgi/hbase/ 国外的站点下载速度慢,可以考虑国内的镜像网站~ 前面已经部署好了hadoop2.2.0单机伪分布式.必须先安装h ...

  4. [UOJ Round#4 A] [#51] 元旦三侠的游戏 【容斥 + 递推】

    题目链接:UOJ - 51 据说这题与 CF 39E 类似. 题目分析 一看题目描述,啊,博弈论,不会!等待爆零吧... 这时,XCJ神犇拯救了我,他说,这题可以直接搜啊. 注意!是用记忆化搜索,状态 ...

  5. websphere安装和mvn dependency:copy-dependencies

    http://www.blogjava.net/paulwong/archive/2009/09/19/295657.html http://ljhzzyx.blog.163.com/blog/sta ...

  6. c#,if 分支语句,条件运算符

    //输入整数a和b, //若a²+b²大于100,则输出a²+b²百位以上数字, //否则输出两数之和 /*Console.Write("请输入整数a:"); int a = in ...

  7. JS添加删除一组文本框并对输入信息加以验证

    在做项目中遇到这样一个问题,就是我们需要添加几组数据到数据库,但是具体几组数据不确定,有客户来填写,比如我们需要添加打折策略,可能个策略有很多组方案,比如“满100打5折,满200打4折,满500打3 ...

  8. sharepoint2007的中文版

    今天终于下载到了sharepoint2007的中文版了,以前微软的测试板也没有中文版,今天终于下载到了,经过测试,用英文版的sn也是可以用的.微软提供的测试版,输入正式的key,就可以变成正式版了.我 ...

  9. 用document.getElementsByTagName()返回的真的是数组吗?

    document.getElementsByTagName()返回的真的是数组吗? 这是这几天开发中遇到的问题. 一个如下的HTML结构: <ul> <li> <li&g ...

  10. 编写Lex和Yacc

    大学课程设计中,有一次是编写Lex(词法分析器的生成器)和Yacc(语法分析器的生成器),编写这类工具软件不是一件容易的事情.这篇文章记录了当时编程时候的主要思想,主要还是编译原理的思想. 准备 Le ...