题目链接: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的更多相关文章

  1. 思维题 HDOJ 5288 OO’s Sequence

    题目传送门 /* 定义两个数组,l[i]和r[i]表示第i个数左侧右侧接近它且值是a[i]因子的位置, 第i个数被选择后贡献的值是(r[i]-i)*(i-l[i]),每个数都枚举它的因子,更新l[i] ...

  2. HDOJ 5288 OO’s Sequence 水

    预处理出每一个数字的左右两边能够整除它的近期的数的位置 OO's Sequence Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 13 ...

  3. 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 ...

  4. HDU 5288 OO‘s sequence (技巧)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5288 题面: OO's Sequence Time Limit: 4000/2000 MS (Jav ...

  5. HDU 5288 OO’s Sequence 水题

    OO's Sequence 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5288 Description OO has got a array A ...

  6. HDU 5288——OO’s Sequence——————【技巧题】

    OO’s Sequence Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  7. Hdu 5288 OO’s Sequence 2015多小联赛A题

    OO's Sequence Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  8. hdu 5288 OO’s Sequence(2015 Multi-University Training Contest 1)

    OO's Sequence                                                          Time Limit: 4000/2000 MS (Jav ...

  9. 【HDOJ】5288 OO’s Sequence

    二分寻找对于指定pos的最左因数点和最右因数点. /* 5288 */ #include <iostream> #include <string> #include <m ...

随机推荐

  1. 制作自己的Cydia发布源

    http://patrickmuff.ch/blog/2013/02/15/create-your-own-cydia-repository-on-ubuntu/ http://www.saurik. ...

  2. Maven的功用所引发的哲学思想

    我们知道Maven有三个仓库 本地仓库 ~/.m2/repository/ 每一个用户也可以拥有一个本地仓库 远程仓库 中央仓库:Maven默认的远程仓库 http://repo1.maven.org ...

  3. foreach的指针问题

    从代码: $arr = array(,,,,); echo '$arr = array(1,2,3,4,5)','<br>'; foreach($arr as $key => &am ...

  4. photoshop,用切片工具等分图片

    一,切片 二,导出: 菜单->文件->存储为Web和设备所用格式 将预设改为PNG-24,然后点存储.

  5. mysql的password()函数和md5函数

    password用于修改mysql的用户密码,如果是应用与web程序建议使用md5()函数, password函数旧版16位,新版41位,可用select length(password('12345 ...

  6. PHP Header 缓存 --- Header 参数说明

    1. Accept:告诉WEB服务器自己接受什么介质类型,*/* 表示任何类型,type/* 表示该类型下的所有子类型,type/sub-type. 2. Accept-Charset:   浏览器申 ...

  7. IOS 单例 创建方式

    @implementation Me static Car *sharedInstance= nil;//声明一个静态对象引用并赋为nil +(Me *) sharedInstance//声明类方法( ...

  8. 嵌入式 Linux进程含义知多少

    理想情况下,您应该明白在您的系统中运行的每一个进程.要获得所有进程的列表,可以执行命令 ps -ef(POSIX 风格)或 ps ax(BSD 风格).进程名有方括号的是内核级的进程,执行辅助功能(比 ...

  9. c/c++ 编译器内存对齐问题

    C语言结构体对齐问题详解 转载自:http://blog.csdn.net/tiany524/article/details/6295551 测试环境32位机 WinXP: 编译器VC6(MS cl. ...

  10. 搭建Eclipse、Resin Web开发环境

    搭建Eclipse.Resin Web开发环境 一.当然是安装java开发环境 参看: Java环境的搭建 http://www.cnblogs.com/ghj1976/archive/2010/04 ...