题目

题目大意

有一个数列AAA,数列上的每个数都是在[li,ri][l_i,r_i][li​,ri​]范围内随机的数。

将这个数列进行稳定排序,得到每个位置在排序后的排名pip_ipi​。

f(A)=∑sipif(A)=\sum s_ip_if(A)=∑si​pi​,求E(f(A))E(f(A))E(f(A))。


思考历程

这种恶心的概率题根本就不知道该怎么思考好吗!

于是打了个暴力,就是枚举所有的情况,然后直接计算。

可是最后不知道为什么爆0了……


正解

E(f(A))=∑siE(pi)E(f(A))=\sum s_i E(p_i)E(f(A))=∑si​E(pi​)

所以我们只需要求出pip_ipi​的期望值就好了。

显然pi=∑j≤i∣aj≤ai∣+∑j&gt;i∣aj&lt;ai∣p_i=\sum_{j\leq i} |a_j \leq a_i|+\sum_{j&gt;i} |a_j&lt; a_i|pi​=∑j≤i​∣aj​≤ai​∣+∑j>i​∣aj​<ai​∣

左右两边是类似的,下面只考虑左边的情况。

设ai=xa_i=xai​=x。对于每个位置jjj,有三种情况:

1、当x&lt;ljx&lt;l_jx<lj​时,位置jjj作出的贡献为000。

2、当lj≤x≤rjl_j \leq x \leq r_jlj​≤x≤rj​时,位置jjj做出的贡献为x−li+1ri−li+1\frac{x-l_i+1}{r_i-l_i+1}ri​−li​+1x−li​+1​。

3、当x&gt;rjx&gt;r_jx>rj​时,位置jjj作出的贡献为111。

不解释……

可以将其转化成一个分段函数的图像来理解一下,前后两段都是与xxx轴平行的线,中间的那段是一段一次函数的图像。

将所有jjj的函数全部加起来,枚举xxx,就可以计算E(pi)E(p_i)E(pi​)。

接下来我们考虑的问题是如何将所有jjj的函数叠加起来,并且能够快速查询一段区间内的和。

在叠加之后,函数长得一定很奇怪……所以不能用数学方法。

考虑使用线段树,用线段树来维护这些东西。

现在有一个奇怪的操作,在线段树内的一段区间上加某段一次函数的图像。

换个说法就是给这段区间加上一个等差数列。

这个怎么维护呢?

我们发现最重要的一点就是标记,关键是如何维护标记。

合并标记的时候,两段一次函数的都在同一段区间内,仔细想想是可以合并的。

一次函数的普遍形式就是y=kx+by=kx+by=kx+b,合并起来之后就是y=(k1+k2)x+(b1+b2)y=(k_1+k_2)x+(b_1+b_2)y=(k1​+k2​)x+(b1​+b2​)。所以可以简单粗暴地相加。

这样维护标记的问题就解决了,整个区间的值都可以维护。

下一个问题就是如何快速地询问,直接维护和就好,在修改的时候加上等差数列的和(千万不要告诉我你不会等差数列求和)。

算法的核心就完成了。

所以我们维护一个这样的线段树,然后从左往右扫,将当前点的贡献(也就是那个分段函数)加入线段树当中,然后区间询问当前点取值范围这一区间内的和,计算E(pi)E(p_i)E(pi​)。

再从右往左扫,实际上是类似的。


代码

我才不会告诉你我先打了博客再打代码……

[JZOJ5232] 【NOIP2017模拟A组模拟8.5】带权排序的更多相关文章

  1. JZOJ 100029. 【NOIP2017提高A组模拟7.8】陪审团

    100029. [NOIP2017提高A组模拟7.8]陪审团 Time Limits: 1000 ms  Memory Limits: 131072 KB  Detailed Limits   Got ...

  2. JZOJ 5328. 【NOIP2017提高A组模拟8.22】世界线

    5328. [NOIP2017提高A组模拟8.22]世界线 (File IO): input:worldline.in output:worldline.out Time Limits: 1500 m ...

  3. JZOJ 5329. 【NOIP2017提高A组模拟8.22】时间机器

    5329. [NOIP2017提高A组模拟8.22]时间机器 (File IO): input:machine.in output:machine.out Time Limits: 2000 ms M ...

  4. JZOJ 5307. 【NOIP2017提高A组模拟8.18】偷窃 (Standard IO)

    5307. [NOIP2017提高A组模拟8.18]偷窃 (Standard IO) Time Limits: 1000 ms Memory Limits: 262144 KB Description ...

  5. JZOJ 5286. 【NOIP2017提高A组模拟8.16】花花的森林 (Standard IO)

    5286. [NOIP2017提高A组模拟8.16]花花的森林 (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Descript ...

  6. JZOJ 5305. 【NOIP2017提高A组模拟8.18】C (Standard IO)

    5305. [NOIP2017提高A组模拟8.18]C (Standard IO) Time Limits: 1000 ms Memory Limits: 131072 KB Description ...

  7. JZOJ 5230. 【NOIP2017模拟A组模拟8.5】队伍统计

    5230. [NOIP2017模拟A组模拟8.5]队伍统计 (File IO): input:count.in output:count.out Time Limits: 1500 ms Memory ...

  8. 【NOIP2017提高A组模拟9.17】信仰是为了虚无之人

    [NOIP2017提高A组模拟9.17]信仰是为了虚无之人 Description Input Output Sample Input 3 3 0 1 1 7 1 1 6 1 3 2 Sample O ...

  9. 【NOIP2017提高A组模拟9.17】猫

    [NOIP2017提高A组模拟9.17]猫 题目 Description 信息组最近猫成灾了! 隔壁物理组也拿猫没办法. 信息组组长只好去请神刀手来帮他们消灭猫.信息组现在共有n 只猫(n 为正整数) ...

  10. 【NOIP2017提高A组模拟9.17】组合数问题

    [NOIP2017提高A组模拟9.17]组合数问题 题目 Description 定义"组合数"S(n,m)代表将n 个不同的元素拆分成m 个非空集合的方案数. 举个例子,将{1,2,3}拆分成2 个 ...

随机推荐

  1. 使用Windbg调试内核

    Windbg是微软开发的免费源码级调试工具.Windbg可以用于Kernel模式调试和用户模式调试,还可以调试Dump文件. 1.从http://www.microsoft.com/whdc/devt ...

  2. 去掉Word 标题编号变成黑框

    问题: 在使用Word编写文档时,提前拟好的标题编号会突然变成黑框(黑色的方框,黑色的矩形),如下图 解决方案: 1.将光标定位到标题中,紧邻黑框的右侧 2.按键盘左方向键使方框变成黑色 3.按键盘的 ...

  3. spark自定义函数之——UDAF使用详解及代码示例

    UDAF简介 UDAF(User Defined Aggregate Function)即用户定义的聚合函数,聚合函数和普通函数的区别是什么呢,普通函数是接受一行输入产生一个输出,聚合函数是接受一组( ...

  4. 2.1_springboot2.x消息介绍&RabbitMQ运行机制

    1.概述 1.大多应用中,可通过消息服务中间件来提升系统异步通信.扩展解耦能力 2.消息服务中两个重要概念: ​ 消息代理(message broker)即消息服务器 和目的地(destination ...

  5. SqlMapClient operation; bad SQL grammar []; nested exception is com.ibatis.common.jdbc.exception.NestedSQLException: InlineParameterMap

    <select id="getResByName" resultClass="Resources" parameterClass="java.l ...

  6. javascript面向对象编程笔记(函数)

    第三章 函数 3.1 什么是函数 一般来说,函数声明通常由以下几部分组成: function子句 函数名称 函数所需参数 函数体 return子句.如果某个函数没有显示的返回值,默认它的返回值为und ...

  7. 2018-10-8-Win10-使用-GHO-安装出现-UWP-软件打开闪退-应用商店无法安装软件

    title author date CreateTime categories Win10 使用 GHO 安装出现 UWP 软件打开闪退 应用商店无法安装软件 lindexi 2018-10-8 18 ...

  8. linux dmesg命令使用

    linux dmesg命令使用 2012-11-27 09:37 2783人阅读 评论(0) 收藏 举报  分类: linux内核与编程(199)  版权声明:本文为博主原创文章,未经博主允许不得转载 ...

  9. 揭秘 Flink 1.9 新架构,Blink Planner 你会用了吗?

    本文为 Apache Flink 新版本重大功能特性解读之 Flink SQL 系列文章的开篇,Flink SQL 系列文章由其核心贡献者们分享,涵盖基础知识.实践.调优.内部实现等各个方面,带你由浅 ...

  10. day17 文件处理及简单函数

    Python之路,Day5 = Python基础5 常亮 用大写来做提示 chr() # 数字转字符ord() # 字符转数字 读文件 要以读文件的模式打开一个文件对象,使用Python内置的open ...