题意:求这个式子 $\sum \limits_{i=1}^{n} \sum \limits_{j=1}^{m} f(i, j) mod (10^9 + 7)$ 的值

就是对每个区间[i, j]枚举区间中的每个数$a_i$到$a_j$, 判断这个$a$是否对[i, j]这个区间内所有数取模都不等于0, 若是,则这个区间满足条件

问有多少个满足条件的区间

比如案例是这样跑的

    int ans=;
for(int i=;i<=;i++)
for(int j=i;j<=;j++)
{
for(int k=i;k<=j;k++) // 注意要枚举[i, j]中的每个数
{
bool flag=;
for(int l=i;l<=j;l++)
if(k!=l && k%l==)
flag=;
if(!flag) // 对区间内所有数取模都不等于0
ans++;
}
}

跟省赛某题很像, 计算每个数a[i]对ans的贡献

比如对于案例 1 2 3 4 5

1这个数字对于答案的贡献是{1}, {1, 2}, {1, 2, 3}, {1, 2, 3, 4}, {1, 2, 3, 4, 5} 这5个区间

2 这个数字对于答案的贡献是{2}, {2, 3}, {2, 3, 4}, {2, 3, 4, 5} 这4个区间   ( {1, 2}区间不满足,因为2%1==0 )

... ...

来看4 这个数

它往左取区间 {4}, {3, 4} 当取到2的时候, 发现4%2==0了,那么就不必再往左了(对于连续的区间, 再往左则必定会经过2,那么该区间就不合法了)

同理,可以想到往右取, 当找到一个数被它取模等于0, 那么就不必再往右了

好了,现在对于一个数a[i], 它左边 到 不合法的数(被它取模等于0)为止 之间有x个数, 右边到不合法的数为止 有y个数

那么a[i]这个数对答案的贡献就是(x+1)*(y+1)

为什么呢?

因为是连续的区间, 所以这个区间的左端点可以取a[i]左边0个数、1个数、2个数... ...x个数;右边0个数、1个数、2个数... ...y个数

左边有(x+1)种取法,右边有(y+1)种, 相乘就是总取法数

那么我们只要找到离a[i]最近的一左一右两个不合法数的位置$l$和$r$, 那么$(i-l)*(r-i)$ 就是a[i]的贡献($i-l-1$就是上面所讲的x)

之后只要遍历每个a, 将每个a的贡献累加起来即是最后答案。

那么现在问题就转化成了如何求一个 离它最近的 能被它整除的数 的位置

我们是这样做的:

开个数组将每个a[i]的倍数都记为i  (比如 a[0]=2, 那么就将2、4、6... ...10000 都记下0号位置;a[x]=y, 就将y、2y、3y... ... 都记下x位置)

就跟筛因子一样   (因为1比较特殊,会退化到$n^2$, 因此特殊处理)   复杂度为O(NlogN)  (N为10000, 因为数最大为10000)

        for(int i=;i<n;i++)
{
if(a[i]==)
one.push_back(i);
else
for(int j=a[i];j<=;j+=a[i])
b[j].push_back(i);
}

因为是按顺序遍历了a数组, 所以记下的位置(比如2 2 3 6 12  对于12记下的是0 1 2 3 4 )一定是递增的

那么就可以二分来寻找离$i$最近的位置

p.s. lower_bound 找的是大于等于x的数位置

upper_bound找的是大于x的数的位置

 const LL mod=1e9+;
int a[];
vector<int> b[];
vector<int> one;
int read()
{
char ch=' ';
int ans=;
while(ch<'' || ch>'')
ch=getchar();
while(ch<='' && ch>='')
{
ans=ans*+ch-'';
ch=getchar();
}
return ans;
} int main()
{
// freopen("1001.in", "r", stdin);
// freopen("out.txt", "w", stdout);
int n;
while(~scanf("%d", &n))
{
for(int i=;i<n;i++)a[i]=read();
// scanf("%d", &a[i]);
for(int i=;i<=;i++)
{
b[i].clear();
b[i].push_back(-);
}
one.clear();
one.push_back(-);
for(int i=;i<n;i++)
{
if(a[i]==)
one.push_back(i);
else
for(int j=a[i];j<=;j+=a[i])
b[j].push_back(i);
}
for(int i=;i<=;i++)
b[i].push_back(n);
one.push_back(n);
LL ans=;
for(int i=;i<n;i++)
{
int p1=lower_bound(b[a[i]].begin(), b[a[i]].end(), i)-b[a[i]].begin()-;
int p2=lower_bound(one.begin(), one.end(), i)-one.begin()-;
int l=max(b[a[i]][p1], one[p2]);
p1=upper_bound(b[a[i]].begin(), b[a[i]].end(), i)-b[a[i]].begin();
p2=upper_bound(one.begin(), one.end(), i)-one.begin();
int r=min(b[a[i]][p1], one[p2]);
// printf("%d %d\n", l, r);
ans=(ans+((i-l)*(r-i))%mod)%mod;
}
printf("%I64d\n", ans%mod);
}
return ;
}

HDOJ 5288

[YY题]HDOJ5288 OO’s Sequence的更多相关文章

  1. HDU 5288 OO’s Sequence 水题

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

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

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

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

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

  4. 思维题 HDOJ 5288 OO’s Sequence

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

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

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

  6. HDOJ 5288 OO’s Sequence 水

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

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

  8. 2015 Multi-University Training Contest 1 - 1001 OO’s Sequence

    OO’s Sequence Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=5288 Mean: 给定一个数列,让你求所有区间上满足 ...

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

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

随机推荐

  1. CSS3选择器:nth-child和:nth-of-type之间的差异

    CSS3选择器:nth-child和:nth-of-type之间的差异 这篇文章发布于 2011年06月21日,星期二,23:04,归类于 css相关. 阅读 57546 次, 今日 143 次 by ...

  2. Linux ThunderBird Exchange 过期

    在Linux上只用Web版处理邮件,就是因为找不到太好的能支持Exchange的邮件客户端.在网上无意中发现了ExQuilla这个Thunderbird的插件,试用了一下还是不错的,很方便,不过只能免 ...

  3. 杂项一之js,<select>标签

    一.在aspx页面中实现 修改与删除页面的跳转 前台js部分: 在上部的js部分中写,根据传过来的id,来经行页面的跳转,并把id传过去 js部分就是实现了一个页面跳转的功能 (还有确认框confir ...

  4. js实现checkbox的全选/取消

    所有的操作都将使用jquery进行. 主要是为了实现指定内容的批量/单独删除操作. 先看一下页面的设计. 实现操作的主要地方是: 首先实现单击“标题”旁的checkbox实现所有条目的选择. 要点:j ...

  5. 重拾C,一天一点点_5

    switch(表达式){    case 整型常量表达式:语句序列    case 整型常量表达式:语句序列    default:语句序列} while(表达式)    语句 for(表达式1; 表 ...

  6. 从省市区多重级联想到的,react和jquery的差别

    在我们的前端项目里经常会用到级联的select,比如省市区这样.通常这种级联大多是动态的.比如先加载了省,点击省加载市,点击市加载区.然后数据通常ajax返回.如果没有数据则说明到了叶子节点.   针 ...

  7. java转义字符

    JAVA中转义字符: 1.八进制转义序列:\ + 1到3位5数字:范围'\000'~'\377'       \0:空字符 2.Unicode转义字符:\u + 四个十六进制数字:0~65535    ...

  8. IOS开发经验分享

    一些IOS开发的心得: 1) [Multiple Threads] IOS多线程注意, 所有的UI操作都必须在主线程上: Any code that will update the UI should ...

  9. StackExchange.Redis的使用

    StackExchange.Redis介绍 有需要了解的和基础的使用可以参考:http://www.cnblogs.com/bnbqian/p/4962855.html StackExchange.R ...

  10. Project Settings -> Editor 设置详解

    Default Behavior Mode (默认行为模式) 定义项目在导入Assets时的默认导入设置,当设置为3D模式时,Unity假设将导入的文件创建为纹理类型(如:PNG文件):当设置为2D时 ...