题意:定义一个数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. 【C语言】结构组成(函数、语句、注释)

    C语言结构组成 一.相关基础知识 二.具体内容 C语言由函数.语句和注释三部分组成: )函数与主函数:     一个C语言源程序可以由一个或多个源文件组成,每个源文件可由一个或多个函数组成,一个源程序 ...

  2. TC2.0中怎样调用汇编程序

    转载于: TC2.0中怎样调用汇编程序 一.概述 TC是美国BORLAND 公司在IBM PC机上开发的一个高效.优化的C编译程序,它自带高效的全屏幕编辑程序,在集成开发环境下可支持编辑.编译.连接调 ...

  3. 物联网操作系统 - Contiki

    What is Contiki? Contiki is an open source operating system for the Internet of Things. Contiki conn ...

  4. android中使用intent来实现Activity带数据跳转

    大家都知道startActivity()是用来切换跳转Activity的.如果想要在另个Activity中出书数据的话.只需要在源activity中使用intent.putExtra()方法传出数据. ...

  5. android studio集成环境搭建

    1 下载JDK(http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html)      An ...

  6. codeforces B. Prison Transfer

    题意:输入n,t,c,再输入n个数,然后问有多少个连续区间内的最大值小于等于t; #include <cstdio> #include <cstring> #include & ...

  7. java学习之二维数组

    java当中的二维数组,存储一组比较特殊的对象.他存储一个数组,同时存储的数组当中又存储着元素. java二维数组的声明方式一: class Arr2Demo { public static void ...

  8. -_-#【CSS】注释

  9. 【转】Java中字符串中子串的查找共有四种方法(indexof())

    原文网址:http://wfly2004.blog.163.com/blog/static/1176427201032692927349/ Java中字符串中子串的查找共有四种方法,如下:1.int ...

  10. 图论(对偶图):COGS 470. [NOI2010]海拔

    470. [NOI2010]海拔 ★★★☆   输入文件:altitude.in   输出文件:altitude.out   简单对比 时间限制:2 s   内存限制:512 MB 海拔 [问题描述] ...