ABC306 A - F

代码不提供

A

题意:吧字符串的每个字符连续输出两遍,记得不要快读,不要忘记输入 $ n $

纪念 Qinzh A 题 WA 掉

B

题意:给定长度为 $ 64 $ 的数组 $ A $,输出 $ \sum_{i = 0}^{63} A_i2^i $

暴力模拟即可

注意要开 unsigned long long

纪念我 WA 了 $ 2 $ 次,第一次用的 int,第二次 long long,第三次 unsigned long long AC

C

题意:给定一个数组 $ A $,里面每个数出现 $ 3 $ 次

把每个数第二次出现的下标排序

只需要用 map < int, int > 来记录出现的次数

然后就过了

D

题意:

孔祥琸去了一家餐厅,他要吃 $ n $ 份饭,每份饭可能是有毒的

他要是吃了有毒的饭,会肚子疼

如果他现在肚子疼,而且又吃了一份有毒的饭,那么世界上的祸害就少了一个,否则他的肚子立刻就会好起来

每份饭有美味度 $ y $,和是否有毒的标识 $ x $,求他不死的前提下能品尝的最大美味度(他可以选择不吃哪份饭)

(题里 $ n $ 的范围是 $ 3 \times 10^5 $,他这么能吃吗?)

这个题我们需要写 dp

设 $ dp_{i, 0/1} $ 表示他吃到第 $ i $ 份饭,和他肚子的状态

然后考虑有毒的情况

他吃的话,肚子一定疼,所以他之前肚子是好的,也就是上一份饭是无毒的

不吃就是,上一盘把上一盘的状态延续

无毒的情况如下:

他如果吃,就不论之前的状态如何,直接更新

否则就可以考虑把之前的情况延续

然后就做完了

E

题意:$ n $ 个数,$ q $ 次操作,每次操作令 $ a_{x_i} = y_i $,每次操作完求前 $ k $ 大之和

这个题考虑平衡树,可以很方便的求出每个数的排名

我们考虑前 $ k $ 大的和用一个变量记录

我们先考虑插入,插入的时候我们需要查询排名,如果能排到前 $ k $ 大,就把原先的最小的顶替掉,同时处理答案

删除的时候,如果删掉了前 $ k $ 个,就把第 $ k + 1 $ 大的顶上

然后每次把 $ a_{x_i} $ 删掉,然后插入 $ y_i $

接着输出答案就可以了

F

题意:有 $ n $ 个长度为 $ m $ 的集合 $ s $,定义 $ f_{s_i, s_j} $ 表示把两个集合并起来中集合 $ i $ 中所有数排名的和(从小到大)

求所有 $ f_{s_i, s_j} $ 保证 $ i < j $

所有集合的数互不相同

考虑计算的东西是 $ \sum_{i = 1}^{n - 1} \sum_{j = i + 1}^{n} f(s_i, s_j) $

这里考虑枚举一个 $ k $,表示枚举 $ s_i $ 中的元素,然后他的排名如下:

在 $ s_i $ 里面的排名是 $ k $,在 $ s_j $ 里面的排名暂时记为 $ c_{j, a_{i, k}} $

然后我们要求的东西就变成了 $ \sum_{i = 1}^{n - 1} \sum_{j = i + 1}^{n} \sum_{k = 1}^{m} (k + c_{j, a_{i, k}}) $

考虑把 $ k $ 提出来: $ \sum_{i = 1}^{n - 1} \sum_{j = i + 1}^{n} \frac{m(m + 1)}{2} + \sum_{i = 1}^{n - 1} \sum_{j = i + 1}^{n} \sum_{k = 1}^{m} c_{j, a_{i, k}} $

这里 $ \sum_{k = 1}^{m} k $ 也就是从 $ 1 $ 加到 $ m $,等于 $ \frac{m(m + 1)}{2} $

然后我们把前面的枚举完全拆开,得到 $ \frac{n(n - 1)}{2} \cdot \frac{m(m + 1)}{2} + \sum_{i = 1}^{n - 1} \sum_{j = i + 1}^{n} \sum_{k = 1}^{m} c_{j, a_{i, k}} $

接下来考虑优化后面,我们可以把所有数离散化后插入到值域树状数组里面,然后一下子求得在所有集合里面的排名

具体操作是倒着枚举,一边计算一边插入,就可以实现不重复,可以自己想一想

然后就可以把 $ j $ 这一层循环给去掉:

$ \frac{n(n - 1)}{2} \cdot \frac{m(m + 1)}{2} + \sum_{i = 1}^{n} \sum_{k = 1}^{m} c_{j, a_{i, k}} $

复杂度是 $ O(nm\log{nm}) $

ABC306 A - F的更多相关文章

  1. Mysql_以案例为基准之查询

    查询数据操作

  2. 在 C# 里使用 F# 的 option 变量

    在使用 C# 与 F# 混合编程的时候(通常是使用 C# 实现 GUI,F#负责数据处理),经常会遇到要判断一个 option 是 None 还是 Some.虽然 Option module 里有 i ...

  3. 如果你也会C#,那不妨了解下F#(7):面向对象编程之继承、接口和泛型

    前言 面向对象三大基本特性:封装.继承.多态.上一篇中介绍了类的定义,下面就了解下F#中继承和多态的使用吧.

  4. 如果你也会C#,那不妨了解下F#(2):数值运算和流程控制语法

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-2.html 一些废话 一门语言火不火,与语言本身并没太大关系,主要看语言的推广. 推广得好,用的 ...

  5. 使用F#开发ASP.NET Core应用程序

    .NET Core 里的F# 在.NET Core刚发布时,就已经添加了对F#的支持.但因为当时F#组件还不完整,而一些依赖包并没有放在Nuget上,而是社区自己放到MyGet上,所以在使用dotne ...

  6. 如果你也会C#,那不妨了解下F#(6):面向对象编程之“类”

    前言 面向对象的思想已经非常成熟,而使用C#的程序员对面向对象也是非常熟悉,所以我就不对面向对象进行介绍了,在这篇文章中将只会介绍面向对象在F#中的使用. F#是支持面向对象的函数式编程语言,所以你用 ...

  7. 如果你也会C#,那不妨了解下F#(5):模块、与C#互相调用

    F# 项目 在之前的几篇文章介绍的代码都在交互窗口(fsi.exe)里运行,但平常开发的软件程序可能含有大类类型和函数定义,代码不可能都在一个文件里.下面我们来看VS里提供的F#项目模板. F#项目模 ...

  8. 如果你也会C#,那不妨了解下F#(4):了解函数及常用函数

    函数式编程其实就是按照数学上的函数运算思想来实现计算机上的运算.虽然我们不需要深入了解数学函数的知识,但应该清楚函数式编程的基础是来自于数学. 例如数学函数\(f(x) = x^2+x\),并没有指定 ...

  9. 如果你也会C#,那不妨了解下F#(3):F#集合类型和其他核心类型

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-3.html 在第一篇中,我们介绍了一些基础数据类型,其实那篇标题中不应该含有"F#&q ...

  10. 如果你也会C#,那不妨了解下F#(1):F# 数据类型

    本文链接:http://www.cnblogs.com/hjklin/p/fs-for-cs-dev-1.html 简单介绍 F#(与C#一样,念作"F Sharp")是一种基于. ...

随机推荐

  1. springboot项目pom文件设置<profile>读取不同的配置文件(网上瞎copy的大把,测试过真实可用)

    这篇文章主要介绍关于springboot如何通过多个properties实现数据库环境部署时自动切换配置的两种方式,部署时切换方式和打包时Maven控制方式.

  2. 智能制造之 SMT 产线监控管理可视化

    前言 随着<中国制造2025>的提出,制造业迎来了全新的发展机遇.更多的企业将制造业信息化技术进行广泛的应用,如 MES 系统.数字孪生以及生产管理可视化等技术的研究应用,已经成为社会各界 ...

  3. 即学即会 Serverless | 如何解决 Serverless 应用开发部署的难题?

    本文节选自<Serverless 开发速查手册>,关注Serverless 公众回复 手册 即可获得下载链接 作者 | 江昱(阿里云 Serverless 产品经理) 破局:工具链体系匮乏 ...

  4. ava进阶(39)--守护线程与定时器

    文档目录: 一.守护线程 二.定时器 ---------------------------------------分割线:正文------------------------------------ ...

  5. 基于Html+腾讯云播SDK开发的m3u8播放器

    周末业余时间在家无事,学习了一下腾讯的云播放sdk,并制作了一个小demo(m3u8播放器),该在线工具是基于腾讯的云播sdk开发的,云播sdk非常牛,可以支持多种播放格式. 预览地址 m3u8pla ...

  6. Verilog Review

    Agenda 目的 Verilog概述 Verilog建模 模块 模块组成 书写建议 时延 Verilog基本语法 标识符 可读性 注释 空格 数据类型 操作数 运算符 条件语句 循环语句 函数 Ve ...

  7. [转帖]超好用的自带火焰图的 Java 性能分析工具 Async-profiler 了解一下

    https://cloud.tencent.com/developer/article/1554194 火焰图 如果你经常遇到 Java 线上性能问题束手无策,看着线上服务 CPU 飙升一筹莫展,发现 ...

  8. [转帖]shell编程之条件语句

    目录 一.条件测试 test命令 文件测试与整数测试 文件测试 整数值比较 字符串测试与逻辑测试 字符串比较 逻辑测试 二.if语句 if单分支语句 单分支结构 if双分支语句 双分支结构 if多分支 ...

  9. [转帖]LSM-Tree:从入门到放弃——入门:基本概念、操作和Trade-Off分析

    https://zhuanlan.zhihu.com/p/428267241 LSM-Tree,全程为日志结构合并树,有趣的是,这个数据结构实际上重点在于日志结构合并,和 tree 本身的关系并不是特 ...

  10. [转帖]Jmeter学习笔记(二十三)——生成HTML性能报告

    https://www.cnblogs.com/pachongshangdexuebi/p/11759316.html 有时候我们写性能报告的时候需要一些性能分布图,JMeter是可以生成HTML性能 ...