hdoj 5288 OO’s Sequence
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5288
//*************头文件区*************
#include<iostream>
#include<cstdio>
#include<vector>
#define N 100010
#define P 1000000007
using namespace std;
int n,tmp,i,j;
int r[N], l[N], q[N], a[N];
long long a1,a2,sum;
vector<int> vec[10010];
int main()
{
freopen("1001.in","r",stdin);
freopen("m1001.out","w",stdout);
while(~scanf("%d",&n)){
for( i = 101; i <= 10000; ++i)
vec[i].clear();
// 清空容器
for( i = 1; i <= n; ++i){
scanf("%d",&a[i]);
l[i] = 0;
r[i] = n+1;
if( a[i] > 100)
vec[a[i]].push_back(i);
// 数据初始化,超过100的数据将下标保存到vec[a[i]]内
}
for( j = 1; j <= 100; ++j){
tmp = 0;
// 暂时保存下标
for( i = 1;i <= n; ++i){
if( a[i] % j ==0 )
l[i] = max(tmp,l[i]);
if( a[i] == j)
tmp = i;
}
tmp = n+1;
for( i = n;i >= 1; --i){
if( a[i] % j ==0)
r[i] = min(tmp,r[i]);
if( a[i] == j)
tmp = i;
}
// 更新以100以内的数为约数的数的左右限制
}
for( i = 101; i <= 10000; ++i)
q[i] = vec[i].size() - 1;
for( i = n; i >= 1; --i){
if(a[i] > 100){
for( j = a[i]; j <= 10000; j = j+a[i]){
while((q[j] >= 0)&&(vec[j][q[j]]>i)){
l[vec[j][q[j]]] = max(l[vec[j][q[j]]],i);
if((q[j] > 0)&&(vec[j][q[j]-1]>i))
q[j]--;
else
break;
}
}
}
}
for( i = 101; i <= 10000; ++i)
q[i] = 0;
// vec下标从0开始?
for( i = 1; i <= n; ++i)
if(a[i] > 100){
for( j = a[i]; j <= 10000; j = j+a[i]){
while((q[j]<vec[j].size())&&(vec[j][q[j]]<i)){
r[vec[j][q[j]]] = min(r[vec[j][q[j]]],i);
if((q[j]<vec[j].size()-1)&&(vec[j][q[j]+1]<i))
q[j]++;
else
break;
}
}
}
sum=0;
for (i=1;i<=n;i++)
{
a1=r[i]-i;
a2=i-l[i];
sum=(sum+a1*a2)%P;
// printf("%lld\n",a1);
}
printf("%I64d\n",sum);
}
}
hdoj 5288 OO’s Sequence的更多相关文章
- 思维题 HDOJ 5288 OO’s Sequence
题目传送门 /* 定义两个数组,l[i]和r[i]表示第i个数左侧右侧接近它且值是a[i]因子的位置, 第i个数被选择后贡献的值是(r[i]-i)*(i-l[i]),每个数都枚举它的因子,更新l[i] ...
- HDOJ 5288 OO’s Sequence 水
预处理出每一个数字的左右两边能够整除它的近期的数的位置 OO's Sequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 13 ...
- HDU 5288 OO’s Sequence [数学]
HDU 5288 OO’s Sequence http://acm.hdu.edu.cn/showproblem.php?pid=5288 OO has got a array A of size ...
- HDU 5288 OO‘s sequence (技巧)
题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5288 题面: OO's Sequence Time Limit: 4000/2000 MS (Jav ...
- HDU 5288 OO’s Sequence 水题
OO's Sequence 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5288 Description OO has got a array A ...
- HDU 5288——OO’s Sequence——————【技巧题】
OO’s Sequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)T ...
- Hdu 5288 OO’s Sequence 2015多小联赛A题
OO's Sequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) ...
- hdu 5288 OO’s Sequence(2015 Multi-University Training Contest 1)
OO's Sequence Time Limit: 4000/2000 MS (Jav ...
- 【HDOJ】5288 OO’s Sequence
二分寻找对于指定pos的最左因数点和最右因数点. /* 5288 */ #include <iostream> #include <string> #include <m ...
随机推荐
- HDU 5366 The mook jong (简单DP)
题意:ZJiaQ希望把木人桩摆在自家的那个由1*1的地砖铺成的1*n的院子里.由于ZJiaQ是个强迫症,所以他要把一个木人桩正好摆在一个地砖上,由于木人桩手比较长,所以两个木人桩之间地砖必须大于等于两 ...
- 【转】vim - tab变空格
vim中将tab自动转换成空格 在vim中,有时需要将tab转换成space.使用ret命令(replace tab).[range]ret[ab]! [new-tabstop] 举例:将第一行到文件 ...
- 【解题报告】[动态规划] RQNOJ PID5 / 能量项链
原题地址:http://www.rqnoj.cn/problem/5 解题思路: 今天刚刚才知道了区间DP..Orz..本来以为是状态压缩DP,后来看到数据量才发现原来不是.后来参考了别人的题解.自己 ...
- lseek()函数
lseek()有个特殊的用途,确定文件是常规文件还是设备.<pre lang="c" escaped="true">off_t currpos;ou ...
- in 和 exist 区别
select * from Awhere id in(select id from B) 以上查询使用了in语句,in()只执行一次,它查出B表中的所有id字段并缓存起来.之后,检查A表的id是否与B ...
- C# Math.Round中国式的四舍五入法
double dou = 1.255; //这种是错误的 double dou_result = Math.Round(dou, 2); //结果: 1.25 dou_result = Math.Ro ...
- 使用Nodejs+mongodb开发地图瓦片服务器
原先地图瓦片服务器采用的是arcgisserver发布的地图服务并进行切片,但ags发布的地图服务很占内存,发布太多的话服务器压力很大.再一个就是ags价太高了. 学习Nodejs之后,发现这是一个可 ...
- String定义与方法
//5种构造方法 public void Con(){ String str = "sfaj"; String str1 = new String("sfajdf&quo ...
- vmware 连网
Nat 这 种方式下,虚拟机的网卡连接到宿主的 VMnet8 上.此时系统的 VMWare NAT Service 服务就充当了路由器的作用,负责将虚拟机发到 VMnet8 的包进行地址转换之后发到实 ...
- [Everyday Mathematics]20150301
设 $f(x)$ 在 $[-1,1]$ 上有任意阶导数, $f^{(n)}(0)=0$, 其中 $n$ 是任意正整数, 且存在 $C>0$, $$\bex |f^{(n)}(x)|\leq C^ ...