题解 CF993E 【Nikita and Order Statistics】

news/2025/1/15 18:46:16/文章来源:https://www.cnblogs.com/EternalEpic/p/18416766

初看这道题,以为又是什么数据结构数数题,没啥思路,结果推式子时搞出了一个类似可以卷积的玩意儿,所以果断 \(FFT\) 解决。

那我们来分析问题:

  1. 这道题里,值域没用,每一个数只要管它与 \(x\) 的相对大小关系即可。如果它小于 \(x\) 那么有贡献,赋值为一,否则为零。然后,可以求前缀和,区间部分和问题往往可以用前缀和配对端点解决。

  2. \(f_i\) 表示前缀和为 \(i\) 的前缀端点数量,\(m\) 为总共比 \(x\) 小的数的个数。显然的,对于恰好有大于一个数比 \(x\) 小的情况中,答案 \(g_k = \sum\limits_{i=0}^{m-k} f_i \times f_{i+k}\)。 这个式子意思就是取两个端点使区间值符合条件,然后用加乘原理统计一下。

  3. 考虑常用技巧,变换顺序,令 \(h_i = f_{m-i}\) ,所以 \(f_{i+k} = h_{m-i-k}\) ,这样的话,\(g\) 就可以写成两者加法卷积了。大功告成。

  4. 不要忘了特殊处理 \(g_0\) ,经过推导可知 \(g_0 = \sum\limits_{i=0}^m \frac{f_i\times{(f_i + 1)}}{2}\) ,暴力算就好。

struct Vector {double x, y;Vector(double _x = 0, double _y = 0) : x(_x), y(_y) {}inline Vector Vary(void) { return Vector(x, -y); }inline bool operator < (const Vector&rhs)const { return x == rhs.x ? y < rhs.y : x < rhs.x; }inline Vector operator - (const Vector&rhs)const { return Vector(x - rhs.x, y - rhs.y); }inline Vector operator + (const Vector&rhs)const { return Vector(x + rhs.x, y + rhs.y); }inline Vector operator * (const double&rhs)const { return Vector(x * rhs, y * rhs); }inline Vector operator / (const double&rhs)const { return Vector(x / rhs, y / rhs); }inline Vector operator * (const Vector&rhs)const { return Vector(x * rhs.x - y * rhs.y, x * rhs.y + y * rhs.x); }
}; typedef Vector Complex;const double PI = std :: acos(-1.0);
const int Maxn = 6e5 + 5;int lim = 1, rev[Maxn];
inline void FFT(int limit, Complex *arr, int type) {for (int i = 0; i < limit; i++)if (i < rev[i]) swap(arr[i], arr[rev[i]]);for (int mid = 1; mid < limit; mid <<= 1) {Complex w0(cos(PI / mid), type * sin(PI / mid));for (int i = 0; i < limit; i += mid << 1) { Complex w(1, 0);for (int j = 0; j < mid; j++, w = w * w0) {Complex x = arr[i + j], y = w * arr[i + j + mid];arr[i + j] = x + y, arr[i + j + mid] = x - y;}}} if (type == -1) for (int i = 0; i < limit; i++) arr[i] = arr[i] / limit;
}int n, m, x; Complex f[Maxn];signed main(void) {read(n), read(x);for (int i = 1, v; i <= n; i++) {read(v); m += v < x ? 1 : 0; f[m].x++;}f[0].x++;while (lim <= m << 1) lim <<= 1;for (int i = 0; i < lim; i++)rev[i] = (rev[i >> 1] >> 1) | ((i & 1) ? (lim >> 1) : 0);ll ret = 0;for (int i = 0; i <= m; i++) f[m - i].y = f[i].x, ret += (ll) f[i].x * (f[i].x - 1) / 2;FFT(lim, f, 1);for (int i = 0; i < lim; i++) f[i] = f[i] * f[i];FFT(lim, f, -1);writeln(ret, ' ');for (int i = 1; i <= m; i++) writeln((ll) (f[m - i].y / 2.0 + 0.5), ' ');for (int i = m + 1; i <= n; i++) writeln(0, " \n"[i == n]);
//	fwrite(pf, 1, o1 - pf, stdout);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/798266.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

白云龙期货投资-第四讲

趋势线波浪理论总结: 1.一般行情完成一次阶段性的上涨或者下跌都会通过三波来完成; 2.这三波上涨和下跌的时间空间,经常同等 3.可以利用波浪理论以上两个特性来判断和预测,还会有几次的上涨或者下跌行情,以及每次大概运行的时间及空间 三种常用实用突破法 1.早盘30mins突破…

中秋 -2024/9/16

今天是中秋假期的第二天,已经过了2/3了,怎么俺滴中秋这么快就没了 今天学习了SQL语句种的查询聚合函数进行查询和Java种的集合 TreeSet,HashSet,LinkedHashSet DQL-聚合函数介绍:将一列数据作为一个整体,进行纵向计算 常见聚合函数count - 统计数量 max - 最大值 min - 最小值 …

李尚杰的第一次作业

这次作业属于哪个课程 https://edu.cnblogs.com/campus/zjlg/rjjc这个作业的目标 熟悉博客的建立,向老师/助教介绍自己并阐述对课程的期待姓名-学号 李尚杰-2022329301146一、个人简介 (一)基本介绍我叫李尚杰,来自22自动化1班,浙江杭州人。我爱好摄影、旅游、看电影、健身…

数木莫系且的旭酱买水问题

dut开区用,在别的情况下该博客无效数木莫系且的旭酱买水问题 创中的招新又双叒叕开始了,“数木莫系且”要开始出招新题了,“数木莫系且”的36位老东西为了想招新题整天废寝忘食、绞尽脑汁、抓耳挠腮、呕心沥血,甚至连水都忘记喝了。“数木莫系且“的不时用日语小声发癫的旭…

字符编码发展史1 — ASCII和EASCII

1. 字符集与字符编码1.1. 字符集 1.2. 字符编码 1.3. 两者的关系2. 字符编码的发展历史2.1. 第一个阶段 ASCII编码2.1.1. ASCII 2.1.2. EASCII1. 字符集与字符编码 1.1. 字符集 字符集(Charcater Set或Charset): 是一个系统支持的所有抽象字符的集合,也就是一系列字符的集合…

[JVM]对象创建过程

Java 对象的创建过程 Java对象创建的过程主要分为五个步骤,下面我将详细介绍这五个步骤。 Step1:类加载检查 虚拟机遇到一条new指令时,首先会去检查这个指令的参数是否能在常量池中定位到这个类的符号引用,并且会检查这个符号引用所指向的类是否已经完成加载、连接和初始化,…

教小模型进行推理

https://arxiv.org/abs/2212.08410 思维链提示在基础层面上是如此成功,以至于它产生了一些被称为 x 链现象的东西。谷歌研究院探索了如何使用 llm 为现有数据集生成 CoT 数据本体,然后如何在 CoT 上微调较小的语言模型。 介绍 众所周知,思维链提示提高了大型语言模型的推理能…

[WesternCTF2018]shrine

打开题目就得到了python代码 import flask import os #导包 app = flask.Flask(__name__) #创建一个flask实例, app.config[FLAG] = os.environ.pop(FLAG) #从操作系统的环境变量中读取名为FLAG的值,并将其存储在Flask的配置中,POP:读取后删除该环境变量@app.route(/) #定义…

MySQL 8.0 Public Key Retrieval is not allowed 错误的解决方法

原文:MySQL 8.0 Public Key Retrieval is not allowed 错误的解决方法 参考:Connection Java - MySQL : Public Key Retrieval is not allowed在使用 MySQL 8.0 时重启应用后提示com.mysql.jdbc.exceptions.jdbc4.MySQLNonTransientConnectionException: Public Key Retrieva…

MobaXterm 密钥生成器

1、MobaXterm 密钥生成器,代码仓库地址: https://gitcode.com/gh_mirrors/mo/MobaXterm-keygen/blob/master/MobaXterm-Keygen.py 2、也可以用我打包好的exe程序,不用安装python环境: https://pan.baidu.com/s/1jo85pQc_kfWhcYmZcc49CQ 提取码:ws10 3、源码:#/usr/bin/e…