Portal --> broken qwq

Description

​   给你一个长度为\(n\)的序列\(a\)和一个正整数\(k\),求满足如下条件的区间\([l,r]\)的数量:\((\sum\limits_{i=l}^r a[i]-max(l,r))\%k=0\),其中\(max\)表示的是该区间的最大值

   数据范围:\(,n<=300000,k<=100000\),保证答案\(<=10^9\)

Solution

​   啊所以说是。。想不到怎么做就想分治吗qwq

​   我们首先可以考虑一种最简单粗暴的求解方式:我们固定一个左端点和最大值,然后看右端点能够移到哪里,然后统计其贡献,快速得出一个区间的表达式值是比较方便的,只要直接维护一个前缀和\(sum\),\(sum[r]-sum[l-1]-mx\)就是表达式的值了

​   然后怎么优化的话。。就是可以将这个思路用到分治里面去

​   对于当前的区间\([l,r]\),我们考虑左端点在\([l,mid]\),右端点在\([mid+1,r]\)中的满足条件的区间, 具体的计算有点迷,考虑将这堆区间再按照最大值的位置分成两类,一类是最大值在\(mid\)及以前,一类是最大值在\(mid\)以后,这两类的计算方式类似,接下来以第一类为例说一下大致过程:一开始将左端点设在\(mid\)处,将右端点设在\(mid+1\)处,每次将左端点往左移一位,然后更新当前位置到\(mid\)这段的最大值作为整个区间的最大值,然后暴力将右端点往右移,这里我们需要一个计数数组来统计贡献,考虑到我们要算的是\(sum[r]-sum[l-1]-mx\equiv 0(mod\ k)\)的区间,而当前\(l\)和\(mx\)是固定的,所以我们可以将右端点的贡献记在计数数组中\(sum[r]\%k\)的位置,调用的时候直接调\((sum[l-1]+mx)\%k\)位置的值就是贡献了

​   如果说是统计第二类的话,就是变成将贡献记在\(sum[l-1]\%k\)的位置上,调用的时候是\((sum[l-1]-mx)\%k\)位置的值即可

​   最后是。。记得清空

   还有就是相同的情况只能算到一边去,也就是其中一类在移的时候是\(<=mx\),另一类是\(<mx\),否则的话会算重

  

   代码大概长这个样子

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. using namespace std;
  5. const int N=300010;
  6. int a[N],sum[N],cnt[N];
  7. int n,m,ans;
  8. void solve(int l,int r){
  9. if (l==r) return;
  10. int mid=l+r>>1,tpl,tpr,mx;
  11. tpl=mid; tpr=mid+1; mx=0;
  12. while (tpl>=l){
  13. mx=max(mx,a[tpl]);
  14. while (tpr<=r&&mx>=a[tpr])
  15. ++cnt[sum[tpr]],++tpr;
  16. ans+=cnt[(sum[tpl-1]+mx)%m];
  17. --tpl;
  18. }
  19. for (int i=mid+1;i<=r;++i) cnt[sum[i]]=0;
  20. tpl=mid; tpr=mid+1; mx=0;
  21. while (tpr<=r){
  22. mx=max(mx,a[tpr]);
  23. while (tpl>=l&&mx>a[tpl])
  24. ++cnt[sum[tpl-1]],--tpl;
  25. ans+=cnt[(m-mx%m+sum[tpr])%m];
  26. ++tpr;
  27. }
  28. for (int i=l;i<=mid;++i) cnt[sum[i-1]]=0;
  29. solve(l,mid);
  30. solve(mid+1,r);
  31. }
  32. int main(){
  33. #ifndef ONLINE_JUDGE
  34. freopen("a.in","r",stdin);
  35. #endif
  36. scanf("%d%d",&n,&m);
  37. sum[0]=0;
  38. for (int i=1;i<=n;++i) scanf("%d",a+i),sum[i]=(sum[i-1]+a[i])%m;
  39. solve(1,n);
  40. printf("%d\n",ans);
  41. }

Yura的更多相关文章

  1. Looksery Cup 2015 F - Yura and Developers 单调栈+启发式合并

    F - Yura and Developers 第一次知道单调栈搞出来的区间也能启发式合并... 你把它想想成一个树的形式, 可以发现确实可以启发式合并. #include<bits/stdc+ ...

  2. codeforces 549F Yura and Developers(分治、启发式合并)

    codeforces 549F Yura and Developers 题意 给定一个数组,问有多少区间满足:去掉最大值之后,和是k的倍数. 题解 分治,对于一个区间,找出最大值之后,分成两个区间. ...

  3. 【Codeforces549F】Yura and Developers [单调栈][二分]

    Yura and Developers Time Limit: 20 Sec  Memory Limit: 512 MB Description Input Output Sample Input 4 ...

  4. Codeforces 549F Yura and Developers

    probelm 题意 给定一个序列和一个mod值,定义[l,r]合法当l到r的全部元素和减去当中的最大值的结果能够整除mod.问共同拥有多少区间合法. 思路 一開始想的分治. 对于一个[l,r]我们能 ...

  5. ●CodeForces 549F Yura and Developers

    题链: http://codeforces.com/problemset/problem/549/F题解: 分治,链表. 考虑对于一个区间[L,R],其最大值在p位置, 那么答案的贡献就可以分为3部分 ...

  6. Swing做的非阻塞式仿飞秋聊天程序

    采用Swing 布局 NIO非阻塞式仿飞秋聊天程序, 切换皮肤颜色什么的小功能以后慢慢做 启动主程序. 当用户打开主程序后自动获取局域网段IP可以在 设置 --> IP网段过滤, 拥有 JMF ...

  7. 从零开始学习jQuery (九) jQuery工具函数

    一.摘要 本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,  即使你会使用jQuery也能在阅读中发现些许秘籍. 我们经常要使用脚本处理各种业务逻辑, 最常见的就 ...

  8. 【原创】Android 对话框的使用

    对话框即Dialog .google的官方解释:A dialog is usually a small window that appears in front of the current Acti ...

  9. Yandex 2013Q(Atoms: There and Back Again-贪心+模拟+List)

    Atoms: There and Back Again Time limit 2 seconds Memory limit 256Mb Input stdin Output stdout Legend ...

随机推荐

  1. ESP8266 NON-OS SDK 和 RTOS SDK实现GPIO中断不同点

    ESP8266 Non-OS SDK 和 RTOS SDK 实现GPIO的方法稍有不同: 对于 Non-OS SDK,比如需要把 MTDO 配置成输入,同时下降沿触发中断: gpio_init(voi ...

  2. JMeter学习工具简单介绍

    JMeter学习工具简单介绍   一.JMeter 介绍 Apache JMeter是100%纯JAVA桌面应用程序,被设计为用于测试客户端/服务端结构的软件(例如web应用程序).它可以用来测试静态 ...

  3. Java EE JavaBean组件

    一.简介 JavaBean组件是一些可移植.可重用并可组装到应用程序中的Java类,类必须是具体的和公共的. 符合下列设计规则的任何Java类均是以JavaBean: 1.对数据类型“protype” ...

  4. 使用Photon引擎进行unity网络游戏开发(一)——Photon引擎简介

    使用Photon引擎进行unity网络游戏开发(一)--Photon引擎简介 Photon PUN Unity 网络游戏开发 Photon引擎简介: 1. 服务器引擎: 服 务 器 引 擎 介 绍 服 ...

  5. 阿里云服务器Centos上Apache安装SSL证书配置Https

    首先我们先去阿里云申请一个免费的SSL证书(https://common-buy.aliyun.com/?spm=5176.7968328.1266638..5e971232BzMSp5&co ...

  6. Echarts简单图表

    一.实现要点 常用可视化图表库 Echarts HighCharts D3.js neo4j (NOSQL) 1.导入js库 <script type="text/javascript ...

  7. HIVE简介及安装

    一.简介 百度百科HIVE定义: hive是基于Hadoop的一个数据仓库工具,可以将结构化的数据文件映射为一张数据库表,并提供简单的sql查询功能,可以将sql语句转换为MapReduce任务进行运 ...

  8. js 零零散散的总结。

    Array.slice.call(arguments);可以将一个类数组转化为数组. Array.from() ,[...arr];也可以将一个类数组转化为数组(es6). (function() { ...

  9. Wormholes POJ 3259(SPFA判负环)

    Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ...

  10. Scrum立会报告+燃尽图(十月十日总第一次):选题

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2190 Scrum立会master:付佳 一.小组介绍 组长:付佳 组员: ...