被tkj大爷艹爆了5555整套模拟赛都是神仙思路题

那么这题题解

还有一个神仙做法,zory巨神在考场上找规律AC,自己都不会证。。我证明了一下(然而这货还是不认可自己的做法)

按照分割点的思路,我们for循环一次,每次找到比当前点小且最远的点,ans+=j-i+1。毫无疑问,当前点的位移到该点之后停止,分割点的产生时间也就是距离。对于一个数,停下当且仅当它撞到了比他大的数,考虑计数和实际走的差别,对于两个数x,y,x在前且<y,设a是x的目标点,b是y的目标点,必有a<b,可以发现对于计数,第一次加上的是x~y y~a,第二次加上的是y~a a~b的贡献,而实际上,第一次加的是x~y y~a a~b,第二次加的是y~a,而这两个值是相等的。

#include<cstdio>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
using namespace std;
typedef long long LL;
const LL mod=1e9+;
int read()
{
int x=,f=;char ch=getchar();
while(ch<''||''<ch){if(ch=='-')f=-;ch=getchar();}
while(''<=ch&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
} LL a[],up[],lw[];
LL l[],suml[],sumli[];
int main()
{
int n,x,y;
n=read();
for(int i=;i<=n;i++)
x=read(), y=read(), a[x]=y; //----------------------------------------------------- up[n-]=a[n-];for(int i=n-;i>=;i--)up[i]=max(up[i+],a[i]);
lw[]=a[]; for(int i=;i<n;i++) lw[i]=min(lw[i-],a[i]); int now=n;
for(int i=;i<n;i++)
while(now>lw[i])l[--now]=i;
while(now>)l[--now]=n-; for(int i=n-;i>=;i--)
{
suml[i]=(suml[i+]+l[i])%mod;
sumli[i]=(sumli[i+]+l[i]*(n-i)%mod)%mod;
} //----------------------------------------------------- LL ans=,d;
for(int i=;i<=n;i++)
{
d=(i*(up[i]-lw[i])*(up[i]+lw[i]+)/)%mod;
ans=(ans+d)%mod; d=i*lw[i]%mod*(up[i]-lw[i])%mod;
ans=((ans-d)%mod+mod)%mod; d=(sumli[lw[i]]-sumli[up[i]])%mod-(suml[lw[i]]-suml[up[i]])*(n-up[i])%mod;
ans=((ans-d)%mod+mod)%mod;
}
printf("%lld\n",ans); return ;
}

最新文章

  1. PDFobject插件使用,PDF在线查看插件
  2. iis Server Error in &#39;/&#39; Application
  3. Scramble String
  4. 利用zip(或者phar)协议进行本地文件包含
  5. char与varchar区别-转
  6. NOR Flash擦写和原理分析 (二)
  7. OpenCV畸变校正原理以及损失有效像素原理分析
  8. invalid bound statement (not found)
  9. Egg.js 中入参的校验
  10. ARP协议分析
  11. 第一个Jsp页面,基于普元EOS
  12. Vue + Element UI 实现权限管理系统 前端篇(十五):嵌套外部网页
  13. java-Unicode与中文的转换
  14. C++用new来创建对象和非new来创建对象的区别
  15. bzoj4784【zjoi2017】仙人掌
  16. bzoj 1176: [Balkan2007]Mokia&amp;&amp;2683: 简单题 -- cdq分治
  17. Elasticsearch中document的基础知识
  18. Entity Framework 高性能 泛型缓存+动态Lambda
  19. OpenStack系列
  20. [xsy1232]Magic

热门文章

  1. 文字水平居中和垂直居中的CSS
  2. Leetcode0092 &amp; 0206--Reverse Linked List 链表逆转
  3. 搭建Hadoop所遇过的坑
  4. 【PostgreSQL-9.6.3】函数(1)--数值型函数
  5. PHP执行Mysql数据库的备份和还原
  6. msmq消息队列使用场景
  7. (转)基于MVC4+EasyUI的Web开发框架经验总结(11)--使用Bundles处理简化页面代码
  8. C# MVC 获得程序运行路径
  9. 关于MySQL,Oracle和SQLServer的特点以及之间区别
  10. Tomcat 服务器中jsp页面乱码