| 区间求最值 |
| Time Limit: 3000ms, Special Time Limit:7500ms, Memory Limit:32768KB |
| Total submit users: 68, Accepted users: 45 |
| Problem 11460 : No special judgement |
| Problem description |
| 给定一个长度为N 的数组,有q个询问,每个询问是求在数组的一段区间内那个元素的因子的个数最大,比如24的因子的个数就是8。 |
| Input |
| 首先是一个整数t,表示有t组测试数据,每组测试数据的第一行是一个整数N(1<=N<=10^6),第二行有N个整数ai(1<=ai<=10^6,i=1,2,.....N)表示数组的元素。第三行有一个整数q(1<=q<=10^5),代表有q个询问,接下来每一行有两个整数,li,ri(li<=ri,li>=1,ri<=N).代表数组的一段区间,并且li+1>=li,ri+1>=ri。 |
| Output |
| 对于每组数据的每个询问都输出一个整数表示在这段区间里面元素因子个数的最大值。 |
| Sample Input |
1 10 2 3 5 6 9 11 12 36 39 44 3 2 6 3 8 3 9 |
| Sample Output |
4 9 9 |
| Problem Source |
| HUNNU Contest
这题感觉很巧妙,首先学到了怎么把给定范围因子数打表,然后 怎么降低时间复杂度。 如果打表后每次直接在给定范围内比较出最大值是会超时的,但是我们可以把前一次比较出来的最大值下标赋值出来,下次查找的话,直接从这个下标开始,会节约很多时间。
#include
|