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 ...
随机推荐
- Http进行网络通信
http使用get的方式进行网络通信: package com.testGet; import java.io.BufferedReader; import java.io.IOException; ...
- 长期演进技术(LTE,Long Term Evolution)
/********************************************************************************* * 长期演进技术(LTE,Long ...
- 你能识别这些科技公司的真假logo吗?
快告诉我,不止我一个眼瞎~
- 包装类-Character
1,isDigit();是否是数字 char c = '1'; boolean bool = Character.isDigit(c); System.out.println(bool);//true ...
- [Everyday Mathematics]20150224
设 $A,B$ 是 $n$ 阶实对称矩阵, 它们的特征值 $>1$. 试证: $AB$ 的特征值的绝对值 $>1$.
- 程序世界系列之-struts2安全漏洞引发的安全杂谈(上)
目录: 1.讨论关于struts 安全问题. 2.黑客文化. 3.如何降低安全漏洞的出现. 4.忠告建议. 题记: 这篇文章本来很早应该和大家见面的,中间由于个人原因调整了系列文章发布时间,实属罪过. ...
- MATLAB 通过二进制读写文件
这几天在做信息隐藏方面的应用,在读写文本文件时耗费许久,故特别的上网学习一二,这里给出一常用读写,其他的都类似. 很多时候,我们都要将一个.txt以二进制方式读出来,操作后在恢复成.txt文本. ma ...
- kali2 vmtools
root@kali:~# cat /etc/apt/sources.list# Regular Repositoriesdeb http://http.kali.org/kali sana main ...
- 《java数据结构与算法》笔记-CH4-8栈结构实现后缀表达式计算结果
/** * 中缀表达式转换成后缀表达式: 从输入(中缀表达式)中读取的字符,规则: 操作数: 写至输出 左括号: 推其入栈 右括号: 栈非空时重复以下步骤--> * 若项不为(,则写至输出: 若 ...
- F2063 Could not compile used unit 'tt.pas'
install packge error F2063 Could not compile used unit 'tt.pas' 有可能是工程的pas文件相对路径不对.在工程管理看是否能打开文件,如果打 ...