数学+dp HDOJ 5317 RGCDQ
/*
题意:给一个区间,问任意两个数的素数因子的GCD最大
数学+dp:预处理出f[i],发现f[i] <= 7,那么用dp[i][j] 记录前i个f[]个数为j的数有几个,
dp[r][j] - dp[l-1][j]表示区间内j的个数,情况不多,分类讨论一下
*/
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <cmath>
using namespace std; const int MAXN = 1e6 + ;
const int INF = 0x3f3f3f3f;
bool is_prime[MAXN];
int f[MAXN];
int dp[MAXN][];
int cnt[];
int n; int GCD(int a, int b) {
return (b == ) ? a : GCD (b, a % b);
} void solve(void) {
memset (is_prime, true, sizeof (is_prime));
for (int i=; i<=n; ++i) {
if (is_prime[i]) {
for (int j=i; j<=n; j+=i) {
f[j]++; is_prime[j] = false;
}
}
}
} void work(void) {
memset (dp, , sizeof (dp));
for (int i=; i<=n; ++i) {
for (int j=; j<=; ++j) {
dp[i][j] = dp[i-][j];
}
dp[i][f[i]]++;
}
} int main(void) { //HDOJ 5317 RGCDQ
//freopen ("B.in", "r", stdin);
n = ;
solve (); work(); int T;
scanf ("%d", &T);
while (T--) {
int l, r;
scanf ("%d%d", &l, &r);
bool ok = false;
for (int i=; i>=; --i) {
if (dp[r][i] - dp[l-][i] >= ) {
printf ("%d\n", i); ok = true; break;
}
}
if (!ok) {
if(dp[r][] - dp[l-][] == && dp[r][] - dp[l-][] == ) {
printf("2\n");
} else if(dp[r][] - dp[l-][] == && dp[r][] - dp[l-][] == ) {
printf("2\n");
} else if(dp[r][] - dp[l-][] == && dp[r][] - dp[l-][] == ) {
printf("2\n");
} else {
printf("1\n");
}
}
} return ;
}
数学+dp HDOJ 5317 RGCDQ的更多相关文章
- hdoj 5317 RGCDQ
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5317 #include<stdio.h> ; int F[MAXN]; bool flag ...
 - 2015 HDU 多校联赛 5317 RGCDQ 筛法求解
		
2015 HDU 多校联赛 5317 RGCDQ 筛法求解 题目 http://acm.hdu.edu.cn/showproblem.php? pid=5317 本题的数据量非常大,測试样例多.数据 ...
 - 数学+DP Codeforces Round #304 (Div. 2) D. Soldier and Number Game
		
题目传送门 /* 题意:这题就是求b+1到a的因子个数和. 数学+DP:a[i]保存i的最小因子,dp[i] = dp[i/a[i]] +1;再来一个前缀和 */ /***************** ...
 - hdu 5317 RGCDQ (2015多校第三场第2题)素数打表+前缀和相减求后缀(DP)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5317 题意:F(x) 表示x的不同质因子的个数结果是求L,R区间中最大的gcd( F(i) , F(j ...
 - 找规律/数位DP HDOJ 4722 Good Numbers
		
题目传送门 /* 找规律/数位DP:我做的时候差一点做出来了,只是不知道最后的 is_one () http://www.cnblogs.com/crazyapple/p/3315436.html 数 ...
 - hdu 5317 RGCDQ(前缀和)
		
题目链接:hdu 5317 这题看数据量就知道需要先预处理,然后对每个询问都需要在 O(logn) 以下的复杂度求出,由数学规律可以推出 1 <= F(x) <= 7,所以对每组(L, R ...
 - 递推DP HDOJ 5328 Problem Killer
		
题目传送门 /* 递推DP: 如果a, b, c是等差数列,且b, c, d是等差数列,那么a, b, c, d是等差数列,等比数列同理 判断ai-2, ai-1, ai是否是等差(比)数列,能在O( ...
 - 拓扑排序+数学+DP【洛谷P1685】 游览
		
P1685 游览 题目描述 顺利通过了黄药师的考验,下面就可以尽情游览桃花岛了! 你要从桃花岛的西头开始一直玩到东头,然后在东头的码头离开.可是当你游玩了一次后,发现桃花岛的景色实在是非常的美丽!!! ...
 - HDU 1041 Computer Transformation 数学DP题解
		
本题假设编程是使用DP思想直接打表就能够了. 假设是找规律就须要数学思维了. 规律就是看这些连续的0是从哪里来的. 我找到的规律是:1经过两次裂变之后就会产生一个00: 00经过两次裂变之后也会产生新 ...
 
随机推荐
- [转]安装openoffice,并且配置为windows服务
			
[转]安装openoffice,并且配置为windows服务 http://blog.csdn.net/zzzz3621/article/details/18400277 下载windows reso ...
 - jQuery ajax的traditional参数的作用
			
一般的,可能有些人在一个参数有多个值的情况下,可能以某个字符分隔的形式传递,比如页面上有多个checkbox: ? 1 2 3 4 5 6 $.ajax{ url:"xxxx&q ...
 - 针对《来用》的NABC分析
			
项目名:<来用> 特点:拥有以往win7在内的众多小游戏 NABC分析 N(need需求): 之所以有这个想法是因为,在WIN7,XP系统中往往有很多众所周知的小游戏(比如扫雷),但是在w ...
 - PHP错误The server encountered an internal error or misconfiguration and was unable to complete your re
			
我的笔记本电脑上的环境安装了很多次,但是运行项目时总是会报The server encountered an internal error or misconfiguration and was un ...
 - 利用checkbox的到值,并且存到数据库修改的话要显示之前选择的
			
在前台当然是利用checkbox来得到复选框的语言:{% for language in languages%}<input type="checkbox" name=&qu ...
 - android 自动化压力测试-monkey  1 实践
			
Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中.它向系统发送伪随机的用户事件流(如按键输入.触摸屏输入.手势输入等),实现对正在开发的应用程序进行压力测试.Monkey ...
 - 01.FastDFS的安装部署
			
1.FastDFS简介 (1)FastDFS的功能介绍 FastDFS是一个开源的分布式文件系统,它对文件进行管理,功能包括:文件存储.文件同步.文件访问(文件上传.文件下载)等,解决了大容量存储和负 ...
 - hdu 4046 Panda 树状数组
			
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4046 When I wrote down this letter, you may have been ...
 - 【BZOJ】【2500】幸福的道路
			
树形DP+单调队列优化DP 好题(也是神题……玛雅我实在是太弱了TAT,真是一个250) 完全是抄的zyf的……orz我还是退OI保平安吧 第一步对于每一天求出一个从第 i 个点出发走出去的最长链的长 ...
 - 土地购买 usaco 斜率优化
			
看这道题的时候,感觉很难,因为数据范围比较大,很难dp: 后来想到了[书柜的尺寸]这道题,也是一道dp,曾经看了那道题的题解而深有启发: 这道题每组的付费只与这一组长宽的最大值有关,也就是说要分组,一 ...